/* ============================================================
   HEXIO UI KIT — Product-mock components for marketing landings
   Brand: hexio.work · Damos en el Blanco × Núvol Digital
   Depends on hexio.css (uses its tokens: --ink, --lime, --paper, …)
   ============================================================ */

/* ---------- 0. Shared base ---------- */
[class^="uik-"], [class*=" uik-"] {
  --uik-pad: var(--s-5);
  --uik-radius: var(--r-md);
  --uik-line: var(--line);
  font-family: var(--font-sans);
  color: var(--fg);
  container-type: inline-size;
}

.uik-card {
  position: relative;
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--uik-line);
  border-radius: var(--uik-radius);
  padding: var(--uik-pad);
  overflow: hidden;
  box-shadow: var(--sh-card);
}

/* Tiny corner-hex badge — shared decoration */
.uik-corner-hex {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 18px;
  height: 18px;
  background: var(--lime);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  pointer-events: none;
  opacity: 0.9;
}
.uik-corner-hex--coral { background: var(--coral); }
.uik-corner-hex--ink { background: var(--ink); }

/* Hex pill (status) — shared */
.uik-hexpill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 18px;
  background: var(--lime);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  position: relative;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
.uik-hexpill--ink { background: var(--ink); color: var(--paper); }
.uik-hexpill--coral { background: var(--coral); color: var(--paper); }
.uik-hexpill--cream { background: var(--cream); color: var(--ink); }

/* Hex marker (timeline / list dot) */
.uik-hexmark {
  display: inline-block;
  width: 10px;
  height: 10px;
  background: var(--lime);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  flex-shrink: 0;
}
.uik-hexmark--coral { background: var(--coral); }
.uik-hexmark--ink { background: var(--ink); }
.uik-hexmark--ghost { background: var(--mist); }

/* Component header — shared row above each mock */
.uik-head {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}
.uik-head__title {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0;
}
.uik-head__sub {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-mute);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-left: auto;
}

/* ---------- Global overflow protection for ALL ui-kit components ---------- */
/* Only applied to ROOT component containers — never cascades to children.
   Cascading min-width: 0 to children was causing flex items to collapse and
   text to wrap character-by-character (vertical text bug). */
[class^="uik-"]:not([class*="__"]) {
  max-width: 100%;
}

/* ---------- 1. Invoice — .uik-invoice ---------- */
.uik-invoice {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  position: relative;
  box-shadow: var(--sh-card);
  container-type: inline-size;
  min-width: 0;
  overflow: hidden;
}
.uik-invoice__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--s-3);
  padding-bottom: var(--s-4);
  border-bottom: 1px solid var(--line);
  margin-bottom: var(--s-4);
}
.uik-invoice__logo {
  width: 36px; height: 36px;
  background: var(--ink);
  display: inline-flex; align-items: center; justify-content: center;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-invoice__logo::after {
  content: "";
  width: 12px; height: 12px;
  background: var(--lime);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-invoice__num {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg-soft);
  text-align: right;
}
.uik-invoice__num strong {
  display: block;
  color: var(--fg);
  font-size: 15px;
  letter-spacing: 0.02em;
  font-weight: 600;
  white-space: nowrap;
}
@container (max-width: 320px) {
  .uik-invoice__num { font-size: 11px; }
  .uik-invoice__num strong { font-size: 13px; }
}
.uik-invoice__parties {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-4);
  margin-bottom: var(--s-4);
}
.uik-invoice__party h4 {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--fg-mute);
  margin: 0 0 4px;
  font-weight: 500;
}
.uik-invoice__party p {
  margin: 0;
  font-size: 12.5px;
  color: var(--fg);
  line-height: 1.4;
}
.uik-invoice__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  margin-bottom: var(--s-3);
}
.uik-invoice__table th,
.uik-invoice__table td {
  padding: 6px 4px;
  text-align: left;
  border-bottom: 1px dashed var(--line);
}
.uik-invoice__table th {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-mute);
  font-weight: 500;
}
.uik-invoice__table td:nth-child(2),
.uik-invoice__table td:nth-child(3),
.uik-invoice__table td:nth-child(4),
.uik-invoice__table th:nth-child(2),
.uik-invoice__table th:nth-child(3),
.uik-invoice__table th:nth-child(4) {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.uik-invoice__totals {
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: flex-end;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-soft);
  margin-bottom: var(--s-3);
}
.uik-invoice__totals .row {
  display: flex; gap: var(--s-4);
  width: 60%; justify-content: space-between;
}
.uik-invoice__total-big {
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 600;
  color: var(--fg);
  letter-spacing: -0.01em;
  margin-top: 6px;
}
.uik-invoice__foot {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px solid var(--line);
  margin-top: var(--s-3);
}
.uik-invoice__qr {
  width: 40px; height: 40px;
  background:
    linear-gradient(45deg, var(--ink) 25%, transparent 25%, transparent 75%, var(--ink) 75%),
    linear-gradient(45deg, var(--ink) 25%, transparent 25%, transparent 75%, var(--ink) 75%) 4px 4px,
    var(--cream);
  background-size: 8px 8px;
  border: 1px solid var(--ink);
  flex-shrink: 0;
}
.uik-invoice__qr-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-mute);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ---------- 2. Bank reconciliation — .uik-bank ---------- */
.uik-bank {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  position: relative;
  box-shadow: var(--sh-card);
}
.uik-bank__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s-4);
  flex-wrap: wrap;
  gap: var(--s-2);
}
.uik-bank__progress {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-soft);
}
.uik-bank__progress strong { color: var(--fg); }
.uik-bank__cols {
  display: grid;
  grid-template-columns: 1fr 32px 1fr;
  gap: var(--s-3);
  align-items: stretch;
}
.uik-bank__col h5 {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--fg-mute);
  margin: 0 0 var(--s-2);
  font-weight: 500;
}
.uik-bank__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 12px;
  margin-bottom: 6px;
  background: var(--bg);
  transition: border-color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
  position: relative;
}
.uik-bank__row.is-matched {
  border-color: var(--lime-deep);
  background: color-mix(in srgb, var(--lime) 14%, var(--bg));
}
.uik-bank__row.is-pending {
  border-style: dashed;
  color: var(--fg-mute);
}
.uik-bank__row .amount {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: var(--fg);
}
.uik-bank__connector {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  padding: 14px 0;
}
.uik-bank__connector svg {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.uik-bank__row .check {
  display: none;
  font-size: 11px;
  color: var(--ink);
  font-weight: 600;
}
.uik-bank__row.is-matched:hover .label { display: none; }
.uik-bank__row.is-matched:hover .check { display: inline-flex; gap: 4px; align-items: center; }
.uik-bank__row.is-matched:hover .check::before {
  content: "✓";
  color: var(--lime-deep);
  font-weight: 700;
}
@container (max-width: 420px) {
  .uik-bank__cols { grid-template-columns: 1fr; }
  .uik-bank__connector { display: none; }
}

/* ---------- 3. Kanban — .uik-kanban ---------- */
.uik-kanban {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
}
.uik-kanban__cols {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-3);
}
.uik-kanban__col {
  background: var(--cream);
  border-radius: 10px;
  padding: 10px;
  min-height: 200px;
}
.uik-kanban__col h5 {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-soft);
  margin: 0 0 var(--s-2);
  display: flex;
  justify-content: space-between;
  font-weight: 500;
}
.uik-kanban__col h5 .count {
  background: var(--bg);
  border-radius: var(--r-pill);
  padding: 1px 7px;
  font-size: 10px;
}
.uik-kanban__card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  margin-bottom: 6px;
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  position: relative;
  transition: transform var(--dur-fast) var(--ease);
}
.uik-kanban__card .title {
  font-weight: 500;
  color: var(--fg);
  line-height: 1.3;
}
.uik-kanban__card .meta {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-mono); font-size: 10px;
  color: var(--fg-mute);
}
.uik-kanban__card .avatar {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--paper);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 600;
}
.uik-kanban__card .chip {
  display: inline-block;
  padding: 1px 6px;
  background: var(--lime);
  color: var(--ink);
  border-radius: var(--r-pill);
  font-size: 9px;
  font-weight: 500;
}
.uik-kanban__card .chip.coral { background: var(--coral); color: var(--paper); }
.uik-kanban__card.is-dragging {
  box-shadow: 0 14px 30px -12px rgba(11,15,25,0.32);
  transform: rotate(-2deg);
  border-color: var(--ink);
  animation: uik-drag-bob 3.4s ease-in-out infinite;
}
@keyframes uik-drag-bob {
  0%, 100% { transform: rotate(-2deg) translateY(0); }
  50% { transform: rotate(-2deg) translateY(-3px); }
}
@container (max-width: 480px) {
  .uik-kanban__cols { grid-template-columns: 1fr; }
  .uik-kanban__col:nth-child(n+2) { display: none; }
}

/* ---------- 4. Time tracker — .uik-time ---------- */
.uik-time {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
  position: relative;
}
.uik-time__timer {
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
  margin-bottom: var(--s-3);
}
.uik-time__digits {
  font-family: var(--font-mono);
  font-size: 38px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--fg);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.uik-time__digits .sec { color: var(--fg-mute); }
.uik-time__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--coral);
  box-shadow: 0 0 0 0 rgba(255,107,74,0.6);
  animation: uik-pulse-coral 1.6s ease-out infinite;
  display: inline-block;
}
@keyframes uik-pulse-coral {
  0% { box-shadow: 0 0 0 0 rgba(255,107,74,0.55); }
  70% { box-shadow: 0 0 0 10px rgba(255,107,74,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,107,74,0); }
}
.uik-time__project {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  border: 1px dashed var(--line-strong);
  border-radius: 8px;
  font-size: 13px;
  color: var(--fg-soft);
  margin-bottom: var(--s-4);
}
.uik-time__project::before {
  content: "";
  width: 10px; height: 10px;
  background: var(--lime);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-time__heatmap {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-bottom: var(--s-3);
}
.uik-time__heatmap span {
  aspect-ratio: 1;
  border-radius: 3px;
  background: var(--cream);
}
.uik-time__heatmap span[data-h="1"] { background: color-mix(in srgb, var(--lime) 25%, var(--cream)); }
.uik-time__heatmap span[data-h="2"] { background: color-mix(in srgb, var(--lime) 50%, var(--cream)); }
.uik-time__heatmap span[data-h="3"] { background: color-mix(in srgb, var(--lime) 75%, var(--cream)); }
.uik-time__heatmap span[data-h="4"] { background: var(--lime); }
.uik-time__heatmap span[data-h="today"] { background: var(--ink); }
.uik-time__total {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-soft);
  padding-top: var(--s-2);
  border-top: 1px solid var(--line);
}
.uik-time__total strong { color: var(--fg); }

/* ---------- 5. AI chat — .uik-ai ---------- */
.uik-ai {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
  container-type: inline-size;
  min-width: 0;
  overflow: hidden;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
@container (max-width: 480px) {
  .uik-ai__msg { max-width: 100% !important; }
  .uik-ai { padding: var(--s-4); }
}
.uik-ai__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--cream);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink);
  margin-bottom: var(--s-4);
}
.uik-ai__chip::before {
  content: "";
  width: 10px; height: 10px;
  background: var(--lime);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-ai__messages {
  display: flex; flex-direction: column;
  gap: var(--s-3); margin-bottom: var(--s-3);
}
.uik-ai__msg {
  max-width: 92%;
  min-width: 0;
  padding: 10px 14px;
  border-radius: 14px;
  font-size: 13px;
  line-height: 1.45;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}
.uik-ai__msg.user {
  align-self: flex-end;
  background: var(--ink);
  color: var(--paper);
  border-bottom-right-radius: 4px;
}
.uik-ai__msg.bot {
  align-self: flex-start;
  background: var(--cream);
  color: var(--ink);
  border-bottom-left-radius: 4px;
  border-left: 3px solid var(--lime);
  padding-left: 12px;
  position: relative;
}
.uik-ai__lines {
  display: flex; flex-direction: column;
  gap: 4px;
}
.uik-ai__lines span {
  display: block;
  opacity: 0;
  animation: uik-typing 6s var(--ease) infinite;
}
.uik-ai__lines span:nth-child(1) { animation-delay: 0.2s; }
.uik-ai__lines span:nth-child(2) { animation-delay: 1.2s; }
.uik-ai__lines span:nth-child(3) { animation-delay: 2.2s; }
.uik-ai__lines span:nth-child(4) { animation-delay: 3.2s; }
@keyframes uik-typing {
  0%, 5% { opacity: 0; transform: translateY(4px); }
  10%, 80% { opacity: 1; transform: translateY(0); }
  95%, 100% { opacity: 0; transform: translateY(0); }
}
.uik-ai__caret {
  display: inline-block;
  width: 7px; height: 13px;
  background: var(--ink);
  vertical-align: -2px;
  margin-left: 2px;
  animation: uik-blink 0.9s steps(1) infinite;
}
@keyframes uik-blink { 50% { opacity: 0; } }
.uik-ai__chips {
  display: flex; gap: 6px; flex-wrap: wrap;
  padding-top: var(--s-3);
  border-top: 1px solid var(--line);
}
.uik-ai__chips span {
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 4px 10px;
  background: var(--bg);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  color: var(--fg);
  cursor: default;
}
.uik-ai__chips span:first-child { background: var(--lime); border-color: transparent; }

/* ---------- 6. Calendar — .uik-calendar ---------- */
.uik-calendar {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
}
.uik-calendar__head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: var(--s-3);
}
.uik-calendar__head h4 {
  font-family: var(--font-display);
  font-size: 16px;
  margin: 0;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.uik-calendar__nav {
  display: flex; gap: 4px;
}
.uik-calendar__nav button {
  width: 22px; height: 22px;
  border: 1px solid var(--line);
  border-radius: 5px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-soft);
  background: var(--bg);
}
.uik-calendar__weekdays,
.uik-calendar__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
}
.uik-calendar__weekdays span {
  font-family: var(--font-mono);
  font-size: 9px;
  text-transform: uppercase;
  text-align: center;
  color: var(--fg-mute);
  padding: 4px 0;
}
.uik-calendar__day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  font-size: 11px;
  font-family: var(--font-mono);
  color: var(--fg);
  border-radius: 5px;
  position: relative;
  cursor: default;
  transition: background var(--dur-fast) var(--ease);
}
.uik-calendar__day:hover { background: var(--cream); }
.uik-calendar__day.is-mute { color: var(--fg-mute); }
.uik-calendar__day.is-today {
  background: var(--ink);
  color: var(--paper);
  font-weight: 600;
}
.uik-calendar__day .dot {
  width: 4px; height: 4px;
  border-radius: 50%;
  position: absolute;
  bottom: 4px;
  background: var(--lime-deep);
}
.uik-calendar__day .dot.coral { background: var(--coral); }
.uik-calendar__day[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 4px); left: 50%;
  transform: translateX(-50%) translateY(4px);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: none;
  padding: 4px 8px;
  border-radius: 4px;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
  z-index: 10;
}
.uik-calendar__day[data-tooltip]:hover::after {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ---------- 7. Client card — .uik-client ---------- */
.uik-client {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  position: relative;
}
.uik-client__top {
  display: flex; align-items: center; gap: var(--s-3);
}
.uik-client__avatar {
  width: 48px; height: 48px;
  background: var(--lime);
  color: var(--ink);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: -0.02em;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  flex-shrink: 0;
}
.uik-client__id h4 {
  margin: 0 0 2px;
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.015em;
}
.uik-client__id .role {
  font-size: 12px;
  color: var(--fg-soft);
}
.uik-client__sector {
  display: inline-block;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: var(--cream);
  color: var(--ink);
  padding: 2px 8px;
  border-radius: var(--r-pill);
}
.uik-client__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-2);
  padding: var(--s-3) 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.uik-client__stat span {
  display: block;
  font-family: var(--font-mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-mute);
  margin-bottom: 2px;
}
.uik-client__stat strong {
  font-size: 14px;
  font-weight: 600;
  color: var(--fg);
  font-variant-numeric: tabular-nums;
  font-family: var(--font-mono);
}
.uik-client__stat.warn strong { color: var(--coral); }
.uik-client__actions {
  display: flex; gap: 6px; flex-wrap: wrap;
}
.uik-client__actions span {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 5px 10px;
  border-radius: var(--r-pill);
  background: var(--cream);
  color: var(--ink);
  cursor: default;
  transition: background var(--dur-fast) var(--ease);
}
.uik-client__actions span:first-child {
  background: var(--ink); color: var(--paper);
}
.uik-client__actions span::before {
  content: "";
  width: 8px; height: 8px;
  background: currentColor;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  opacity: 0.7;
}
@container (max-width: 320px) {
  .uik-client__stats { grid-template-columns: 1fr; }
}

/* ---------- 8. Pipeline — .uik-pipeline ---------- */
.uik-pipeline {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
}
.uik-pipeline__cols {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-2);
}
.uik-pipeline__col {
  border-radius: 8px;
  padding: 8px;
  min-height: 180px;
}
.uik-pipeline__col[data-stage="lead"] { background: color-mix(in srgb, var(--lime) 18%, var(--bg)); }
.uik-pipeline__col[data-stage="qual"] { background: color-mix(in srgb, var(--lime) 38%, var(--bg)); }
.uik-pipeline__col[data-stage="prop"] { background: color-mix(in srgb, var(--lime-deep) 50%, var(--bg)); }
.uik-pipeline__col[data-stage="won"] { background: color-mix(in srgb, var(--coral) 22%, var(--bg)); }
.uik-pipeline__col h5 {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink);
  margin: 0 0 var(--s-2);
  font-weight: 600;
}
.uik-pipeline__col h5 .total {
  font-family: var(--font-mono);
  font-size: 9px;
  background: var(--bg);
  padding: 1px 6px;
  border-radius: var(--r-pill);
  color: var(--fg-soft);
  font-weight: 500;
}
.uik-pipeline__deal {
  background: var(--bg);
  border-radius: 6px;
  padding: 7px 9px;
  margin-bottom: 6px;
  font-size: 11px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}
.uik-pipeline__deal .name {
  font-weight: 600; color: var(--fg);
  display: block;
}
.uik-pipeline__deal .info {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 10px;
  color: var(--fg-soft);
  margin-top: 3px;
}
.uik-pipeline__deal .value {
  color: var(--fg); font-weight: 600;
}
@container (max-width: 480px) {
  .uik-pipeline__cols { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- 9. Newsletter — .uik-newsletter ---------- */
.uik-newsletter {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
}
.uik-newsletter__subject {
  display: flex; align-items: center;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  padding: 8px 12px;
  margin-bottom: var(--s-3);
  font-size: 13px;
}
.uik-newsletter__subject::before {
  content: "Assumpte:";
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-mute);
  margin-right: 8px;
}
.uik-newsletter__subject .val {
  font-weight: 600;
  color: var(--fg);
}
.uik-newsletter__subject::after {
  content: "";
  width: 1px; height: 14px;
  background: var(--ink);
  margin-left: 4px;
  animation: uik-blink 0.9s steps(1) infinite;
}
.uik-newsletter__editor {
  background: var(--cream);
  border-radius: 8px;
  padding: var(--s-4);
  font-size: 12px;
  line-height: 1.5;
  margin-bottom: var(--s-3);
  position: relative;
}
.uik-newsletter__editor::before {
  content: "";
  position: absolute;
  top: 8px; right: 8px;
  width: 14px; height: 14px;
  background: var(--lime);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-newsletter__editor p {
  margin: 0 0 8px;
}
.uik-newsletter__editor ul {
  margin: 0 0 8px;
  padding-left: 16px;
  list-style: none;
}
.uik-newsletter__editor li {
  position: relative;
  padding-left: 4px;
}
.uik-newsletter__editor li::before {
  content: "";
  position: absolute;
  left: -10px; top: 6px;
  width: 6px; height: 6px;
  background: var(--lime-deep);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-newsletter__cta {
  display: inline-block;
  background: var(--ink);
  color: var(--paper);
  padding: 6px 12px;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
}
.uik-newsletter__foot {
  display: flex; justify-content: space-between; flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-soft);
  padding-top: var(--s-2);
  border-top: 1px solid var(--line);
  gap: 6px;
}
.uik-newsletter__foot strong { color: var(--fg); }

/* ---------- 10. Automation — .uik-automation ---------- */
.uik-automation {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
  position: relative;
}
.uik-automation__flow {
  display: grid;
  grid-template-columns: 1fr 18px 1fr 18px 1fr;
  align-items: center;
  gap: 8px;
}
.uik-auto-node {
  position: relative;
  background: var(--cream);
  padding: 14px 10px;
  text-align: center;
  font-size: 11.5px;
  line-height: 1.3;
  color: var(--ink);
  clip-path: polygon(8% 0, 92% 0, 100% 50%, 92% 100%, 8% 100%, 0 50%);
  min-height: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
}
.uik-auto-node strong {
  display: block;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: 2px;
}
.uik-auto-node--trigger { background: var(--lime); }
.uik-auto-node--cond { background: var(--cream-2); }
.uik-auto-node--action { background: var(--ink); color: var(--paper); }
.uik-auto-node--action strong { color: var(--lime); }
.uik-auto-node .ico {
  width: 14px; height: 14px;
  background: currentColor;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  opacity: 0.6;
  margin-bottom: 2px;
}
.uik-auto-arrow {
  height: 2px;
  background: linear-gradient(90deg, var(--lime), var(--lime-deep));
  position: relative;
}
.uik-auto-arrow::after {
  content: "";
  position: absolute;
  right: -2px; top: 50%;
  transform: translateY(-50%);
  width: 0; height: 0;
  border-left: 6px solid var(--lime-deep);
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
}
.uik-auto-arrow::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--lime);
  animation: uik-pulse-line 2.4s linear infinite;
  transform-origin: 0 50%;
}
@keyframes uik-pulse-line {
  0% { transform: scaleX(0); }
  60% { transform: scaleX(1); }
  100% { transform: scaleX(1); opacity: 0; }
}
@container (max-width: 480px) {
  .uik-automation__flow {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }
  .uik-auto-arrow {
    width: 2px; height: 18px;
    background: linear-gradient(180deg, var(--lime), var(--lime-deep));
    justify-self: center;
  }
  .uik-auto-arrow::after {
    right: 50%; top: auto; bottom: -2px;
    transform: translateX(50%);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 6px solid var(--lime-deep);
    border-bottom: 0;
  }
}

/* ---------- 11. Org chart — .uik-org ---------- */
.uik-org {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
  position: relative;
  overflow: hidden;
}
.uik-org__chart {
  display: flex; flex-direction: column;
  gap: 18px;
  align-items: center;
  position: relative;
}
.uik-org__row {
  display: flex; gap: 14px; justify-content: center;
  position: relative;
}
.uik-org__row::before,
.uik-org__row::after {
  content: "";
  position: absolute;
  background: var(--mist-2);
}
.uik-org__row:not(:first-child)::before {
  top: -18px; left: 25%; right: 25%;
  height: 1px;
}
.uik-org__node {
  width: 90px;
  background: var(--cream);
  padding: 8px 6px;
  text-align: center;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  display: flex; flex-direction: column; align-items: center;
  gap: 2px;
}
.uik-org__node--top { background: var(--lime); }
.uik-org__node--mid { background: var(--cream-2); }
.uik-org__avatar {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--paper);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 600;
  margin-top: 4px;
}
.uik-org__node h6 {
  margin: 2px 0 0;
  font-size: 10px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.1;
}
.uik-org__node .role {
  font-family: var(--font-mono);
  font-size: 8px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-soft);
  margin-bottom: 4px;
}
@container (max-width: 380px) {
  .uik-org__node { width: 70px; }
}

/* ---------- 12. Signature — .uik-signature ---------- */
.uik-signature {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
  position: relative;
}
.uik-signature__doc {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: var(--s-4);
  margin-bottom: var(--s-3);
  position: relative;
}
.uik-signature__doc h5 {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  margin: 0 0 var(--s-3);
  letter-spacing: -0.015em;
}
.uik-signature__lines {
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: var(--s-3);
}
.uik-signature__lines span {
  display: block;
  height: 6px;
  background: var(--mist);
  border-radius: 2px;
}
.uik-signature__lines span:nth-child(1) { width: 92%; }
.uik-signature__lines span:nth-child(2) { width: 88%; }
.uik-signature__lines span:nth-child(3) { width: 95%; }
.uik-signature__lines span:nth-child(4) { width: 70%; }
.uik-signature__row {
  display: flex; align-items: center; gap: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px dashed var(--line);
}
.uik-signature__sign {
  font-family: "Geist", cursive;
  font-style: italic;
  font-size: 22px;
  color: var(--ink);
  letter-spacing: -0.02em;
  position: relative;
  display: inline-block;
  background-image: linear-gradient(transparent 70%, var(--lime) 70%);
  padding: 2px 6px;
}
.uik-signature__stamp {
  width: 56px; height: 56px;
  border: 2px solid var(--coral);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 9px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--coral);
  letter-spacing: 0.05em;
  text-align: center;
  line-height: 1.05;
  transform: rotate(-12deg);
  flex-shrink: 0;
  animation: uik-stamp-in 1s var(--ease-out) backwards;
}
@keyframes uik-stamp-in {
  0% { opacity: 0; transform: rotate(-12deg) scale(2); }
  60% { opacity: 1; transform: rotate(-12deg) scale(0.96); }
  100% { transform: rotate(-12deg) scale(1); }
}
.uik-signature__by {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-soft);
  line-height: 1.35;
  flex: 1;
}
.uik-signature__by strong { color: var(--fg); display: block; }

/* ---------- 13. Modules mosaic — .uik-modules-mosaic ---------- */
.uik-modules-mosaic {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-card);
}
.uik-modules-mosaic__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  padding: 4px;
}
.uik-mod-tile {
  position: relative;
  aspect-ratio: 1 / 1.155;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  background: var(--cream);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 2px;
  color: var(--ink);
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease);
  cursor: default;
}
.uik-mod-tile.is-active { background: var(--lime); }
.uik-mod-tile.is-active-deep { background: var(--lime-deep); }
.uik-mod-tile.is-coral { background: var(--coral); color: var(--paper); }
.uik-mod-tile.is-ghost {
  background: transparent;
  border: 1px dashed var(--line-strong);
  color: var(--fg-mute);
  /* clip-path fights with border, fake with mask */
  -webkit-mask: none;
  mask: none;
}
.uik-mod-tile svg {
  width: 36%;
  height: 36%;
}
.uik-mod-tile .lbl {
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 500;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.uik-mod-tile:hover {
  transform: scale(1.05);
  background: var(--ink);
  color: var(--paper);
}
.uik-mod-tile:hover .lbl {
  max-height: 12px;
  opacity: 1;
}
.uik-mod-tile.is-active:hover { background: var(--ink); color: var(--lime); }
.uik-mod-tile.is-coral:hover { background: var(--ink); color: var(--coral); }

@container (max-width: 480px) {
  .uik-modules-mosaic__grid { grid-template-columns: repeat(4, 1fr); }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .uik-time__dot,
  .uik-ai__lines span,
  .uik-ai__caret,
  .uik-newsletter__subject::after,
  .uik-auto-arrow::before,
  .uik-signature__stamp,
  .uik-kanban__card.is-dragging {
    animation: none !important;
  }
  .uik-ai__lines span { opacity: 1; }
}

/* ===== v4 components ===== */

/* ---------- v4.1. Pricing card — .uik-pricing-card ---------- */
.uik-pricing-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--s-6) var(--s-5) var(--s-5);
  box-shadow: var(--sh-card);
  transition: transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
  overflow: hidden;
}
.uik-pricing-card:hover { transform: translateY(-3px); box-shadow: var(--sh-card-hover); }
.uik-pricing-card__chip {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-soft);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.uik-pricing-card__chip::before {
  content: "";
  width: 10px;
  height: 10px;
  background: var(--mist-2);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-pricing-card__name {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--fg);
}
.uik-pricing-card__price {
  display: flex;
  align-items: baseline;
  gap: var(--s-2);
  flex-wrap: wrap;
  padding-block: var(--s-3);
  border-block: 1px dashed var(--line);
}
.uik-pricing-card__price .from {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-mute);
}
.uik-pricing-card__price .num {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--fg);
  line-height: 1;
}
.uik-pricing-card__price .unit {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-soft);
}
.uik-pricing-card__tier-line {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--fg-mute);
  text-transform: uppercase;
  margin: 0;
}
.uik-pricing-card__features {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  flex-grow: 1;
}
.uik-pricing-card__features li {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: var(--s-3);
  align-items: start;
  font-size: 14px;
  color: var(--fg-soft);
  line-height: 1.5;
}
.uik-pricing-card__features li::before {
  content: "";
  width: 14px;
  height: 14px;
  margin-top: 5px;
  background: var(--lime);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-pricing-card__cta {
  margin-top: var(--s-3);
}
/* Featured variant */
.uik-pricing-card--featured {
  border-color: var(--lime);
  box-shadow: 0 1px 0 var(--lime), 0 32px 64px -28px rgba(11,15,25,0.32);
  background: linear-gradient(180deg, rgba(198,242,78,0.05), transparent 30%);
}
.uik-pricing-card--featured::before {
  content: "Recomanat";
  position: absolute;
  top: 14px;
  right: 14px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: var(--lime);
  color: var(--ink);
  padding: 5px 10px 5px 14px;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
  font-weight: 600;
}
.uik-pricing-card--featured .uik-pricing-card__chip::before { background: var(--lime); }

/* ---------- v4.2. Cost simulator — .uik-cost-simulator ---------- */
.uik-cost-simulator {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  box-shadow: var(--sh-card);
  display: grid;
  gap: var(--s-6);
  grid-template-columns: 1.2fr 1fr;
  align-items: center;
}
.uik-cost-simulator__inputs {
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
}
.uik-cost-simulator__field label {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-3);
  margin-bottom: var(--s-2);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-soft);
}
.uik-cost-simulator__field label strong {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fg);
  text-transform: none;
}
.uik-cost-simulator__field input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 6px;
  background: var(--mist);
  border-radius: var(--r-pill);
  outline: none;
  cursor: pointer;
}
.uik-cost-simulator__field input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 22px;
  height: 22px;
  background: var(--lime);
  border: 2px solid var(--ink);
  border-radius: 50%;
  cursor: grab;
  transition: transform var(--dur-fast) var(--ease);
}
.uik-cost-simulator__field input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.1); }
.uik-cost-simulator__field input[type="range"]::-moz-range-thumb {
  width: 22px;
  height: 22px;
  background: var(--lime);
  border: 2px solid var(--ink);
  border-radius: 50%;
  cursor: grab;
}
.uik-cost-simulator__output {
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--r-md);
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  position: relative;
  overflow: hidden;
}
.uik-cost-simulator__output::after {
  content: "";
  position: absolute;
  top: -20px;
  right: -20px;
  width: 80px;
  height: 80px;
  background: var(--lime);
  opacity: 0.15;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-cost-simulator__output .label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--slate-300);
}
.uik-cost-simulator__output .value {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--lime);
}
.uik-cost-simulator__output .unit {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--slate-300);
}
.uik-cost-simulator__output .disclaimer {
  font-size: 11px;
  color: var(--slate-400);
  margin-top: var(--s-3);
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: var(--s-3);
  line-height: 1.4;
}
@container (max-width: 640px) {
  .uik-cost-simulator { grid-template-columns: 1fr; padding: var(--s-5); }
}

/* ---------- v4.3. Blog card — .uik-blog-card ---------- */
.uik-blog-card {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  overflow: hidden;
  text-decoration: none;
  color: var(--fg);
  transition: transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
  box-shadow: var(--sh-card);
}
.uik-blog-card:hover { transform: translateY(-4px); box-shadow: var(--sh-card-hover); }
.uik-blog-card__thumb {
  aspect-ratio: 4 / 3;
  background: var(--cream);
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--line);
}
.uik-blog-card__thumb svg { width: 56%; height: auto; }
.uik-blog-card__body {
  padding: var(--s-4) var(--s-5) var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.uik-blog-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
}
.uik-blog-card__cat {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: var(--cream);
  color: var(--ink);
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-weight: 600;
}
.uik-blog-card__cat--lime { background: var(--lime); }
.uik-blog-card__cat--coral { background: var(--coral); color: var(--paper); }
.uik-blog-card__date {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-mute);
}
.uik-blog-card__title {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: var(--fg);
  margin: 0;
}
.uik-blog-card__excerpt {
  font-size: 13px;
  color: var(--fg-soft);
  line-height: 1.5;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.uik-blog-card__link {
  margin-top: auto;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: 0.04em;
}
.uik-blog-card:hover .uik-blog-card__link { color: var(--coral); }

/* ---------- v4.4. Changelog entry — .uik-changelog-entry ---------- */
.uik-changelog-entry {
  position: relative;
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: var(--s-5);
  padding: var(--s-4) 0 var(--s-4) var(--s-4);
  border-left: 1px dashed var(--line-strong);
  margin-left: var(--s-3);
}
.uik-changelog-entry::before {
  content: "";
  position: absolute;
  left: -7px;
  top: 24px;
  width: 13px;
  height: 13px;
  background: var(--lime);
  border: 2px solid var(--bg);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.uik-changelog-entry__date {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-mute);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding-top: 6px;
}
.uik-changelog-entry__body {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.uik-changelog-entry__row {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  flex-wrap: wrap;
}
.uik-changelog-entry__version {
  font-family: var(--font-mono);
  font-size: 11px;
  background: var(--ink);
  color: var(--paper);
  padding: 3px 8px;
  border-radius: var(--r-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
}
.uik-changelog-entry__chip {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--r-pill);
  background: var(--cream);
  color: var(--ink);
  font-weight: 600;
}
.uik-changelog-entry__chip--new { background: var(--lime); color: var(--ink); }
.uik-changelog-entry__chip--fix { background: var(--coral); color: var(--paper); }
.uik-changelog-entry__chip--improve { background: var(--cream); color: var(--ink); }
.uik-changelog-entry__title {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fg);
  margin: 0;
  line-height: 1.3;
}
.uik-changelog-entry__desc {
  font-size: 13px;
  color: var(--fg-soft);
  margin: 0;
  line-height: 1.5;
}
@container (max-width: 480px) {
  .uik-changelog-entry { grid-template-columns: 1fr; }
}

/* ---------- v4.5. Role card — .uik-role-card ---------- */
.uik-role-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  transition: transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
  box-shadow: var(--sh-card);
}
.uik-role-card:hover {
  transform: translateY(-2px);
  border-color: var(--ink);
  box-shadow: var(--sh-card-hover);
}
.uik-role-card__avatar {
  width: 52px;
  height: 56px;
  background: var(--lime);
  color: var(--ink);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.02em;
}
.uik-role-card__avatar--coral { background: var(--coral); color: var(--paper); }
.uik-role-card__avatar--ink { background: var(--ink); color: var(--lime); }
.uik-role-card__name {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--fg);
}
.uik-role-card__value {
  font-size: 13px;
  color: var(--fg-soft);
  line-height: 1.5;
  margin: 0;
}
.uik-role-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: var(--s-2);
}
.uik-role-card__chip {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  background: var(--cream);
  color: var(--ink);
  padding: 4px 8px;
  border-radius: var(--r-xs);
  font-weight: 500;
}

/* ---------- v4.6. Modelo 303 IVA mock — .uik-fiscal-303 ---------- */
.uik-fiscal-303 {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  box-shadow: var(--sh-card);
}
.uik-fiscal-303__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--line);
}
.uik-fiscal-303__head h4 {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0;
}
.uik-fiscal-303__head .status {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink);
  background: var(--lime);
  padding: 3px 8px;
  border-radius: var(--r-xs);
  font-weight: 600;
}
.uik-fiscal-303__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.uik-fiscal-303__table th,
.uik-fiscal-303__table td {
  padding: 8px 4px;
  text-align: left;
  border-bottom: 1px dashed var(--line);
}
.uik-fiscal-303__table th {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-mute);
  font-weight: 500;
}
.uik-fiscal-303__table td.casilla {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-mute);
  width: 60px;
}
.uik-fiscal-303__table td.amount {
  font-family: var(--font-mono);
  font-size: 13px;
  text-align: right;
  color: var(--fg);
  font-feature-settings: "tnum" 1;
}
.uik-fiscal-303__total {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
  padding-top: var(--s-3);
  border-top: 2px solid var(--ink);
}
.uik-fiscal-303__total .label {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-soft);
}
.uik-fiscal-303__total .value {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 36px);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--fg);
  font-feature-settings: "tnum" 1;
}
.uik-fiscal-303__total .value.is-positive { color: var(--coral); }

/* ---------- v4.7. Payslip — .uik-payslip ---------- */
.uik-payslip {
  position: relative;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  box-shadow: var(--sh-card);
  overflow: hidden;
}
.uik-payslip::after {
  content: "";
  position: absolute;
  top: -24px;
  right: -24px;
  width: 96px;
  height: 96px;
  background: var(--lime);
  opacity: 0.18;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  pointer-events: none;
}
.uik-payslip__head {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--line);
  position: relative;
  z-index: 1;
}
.uik-payslip__head .name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--fg);
}
.uik-payslip__head .month {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-mute);
}
.uik-payslip__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
  font-size: 13px;
  position: relative;
  z-index: 1;
}
.uik-payslip__row .label { color: var(--fg-soft); }
.uik-payslip__row .amount {
  font-family: var(--font-mono);
  color: var(--fg);
  font-feature-settings: "tnum" 1;
}
.uik-payslip__row.is-deduction .amount { color: var(--coral); }
.uik-payslip__row.is-gross { font-weight: 600; }
.uik-payslip__row.is-gross .amount { color: var(--fg); }
.uik-payslip__deductions {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding: var(--s-3) 0;
  border-block: 1px dashed var(--line);
}
.uik-payslip__net {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
  position: relative;
  z-index: 1;
}
.uik-payslip__net .label {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--fg-soft);
}
.uik-payslip__net .value {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.2vw, 38px);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--fg);
  font-feature-settings: "tnum" 1;
}

/* ---------- v4.8. Modules mesh flow — .flow-modules-mesh ---------- */
.flow-modules-mesh {
  width: 100%;
  height: auto;
  display: block;
  max-width: 720px;
  margin-inline: auto;
}
.flow-modules-mesh .mesh-link {
  fill: none;
  stroke: var(--mist-2);
  stroke-width: 1.2;
  stroke-dasharray: 3 3;
  opacity: 0.7;
}
.flow-modules-mesh .mesh-hex-core {
  fill: var(--ink);
}
.flow-modules-mesh .mesh-hex-core-stroke {
  fill: var(--lime);
}
.flow-modules-mesh .mesh-hex-sat {
  fill: var(--paper);
  stroke: var(--ink);
  stroke-width: 1.4;
}
.flow-modules-mesh .mesh-hex-sat-accent { fill: var(--cream); }
.flow-modules-mesh .mesh-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  fill: var(--ink);
}
.flow-modules-mesh .mesh-label-core {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.01em;
  fill: var(--lime);
}
.flow-modules-mesh .mesh-packet {
  fill: var(--lime);
  filter: drop-shadow(0 0 4px rgba(198,242,78,0.6));
}
.flow-modules-mesh .mesh-packet--p1 { animation: meshTravel1 5.5s linear infinite; }
.flow-modules-mesh .mesh-packet--p2 { animation: meshTravel2 6.2s linear infinite; animation-delay: -1.4s; }
.flow-modules-mesh .mesh-packet--p3 { animation: meshTravel3 5.8s linear infinite; animation-delay: -2.8s; }
.flow-modules-mesh .mesh-packet--p4 { animation: meshTravel4 6.4s linear infinite; animation-delay: -4.1s; }

@keyframes meshTravel1 {
  0%   { transform: translate(220px, 180px); opacity: 0; }
  10%  { opacity: 1; }
  50%  { transform: translate(420px, 80px); opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translate(580px, 180px); opacity: 0; }
}
@keyframes meshTravel2 {
  0%   { transform: translate(360px, 180px); opacity: 0; }
  15%  { opacity: 1; }
  50%  { transform: translate(560px, 260px); opacity: 1; }
  85%  { opacity: 1; }
  100% { transform: translate(420px, 360px); opacity: 0; }
}
@keyframes meshTravel3 {
  0%   { transform: translate(360px, 180px); opacity: 0; }
  15%  { opacity: 1; }
  50%  { transform: translate(180px, 260px); opacity: 1; }
  85%  { opacity: 1; }
  100% { transform: translate(280px, 360px); opacity: 0; }
}
@keyframes meshTravel4 {
  0%   { transform: translate(220px, 180px); opacity: 0; }
  15%  { opacity: 1; }
  50%  { transform: translate(120px, 100px); opacity: 1; }
  85%  { opacity: 1; }
  100% { transform: translate(280px, 40px); opacity: 0; }
}

/* ---------- v4 reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  .flow-modules-mesh .mesh-packet--p1,
  .flow-modules-mesh .mesh-packet--p2,
  .flow-modules-mesh .mesh-packet--p3,
  .flow-modules-mesh .mesh-packet--p4 {
    animation: none !important;
    opacity: 0.6;
  }
  .uik-pricing-card,
  .uik-blog-card,
  .uik-role-card { transition: none !important; }
}

/* ===================================================
   v5 epic components — dashboards, productivity, 
   communication, storytelling, marketing
   =================================================== */

/* --- v5.1 Dashboard hero (full-page mock) --- */
.uik-dashboard-hero {
  display: grid;
  grid-template-columns: 220px 1fr;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg);
  overflow: hidden;
  box-shadow: var(--sh-card);
  font-size: 13px;
  container-type: inline-size;
}
.uik-dashboard-hero__sidebar { background: var(--ink); color: var(--paper); padding: 16px; display: flex; flex-direction: column; gap: 10px; }
.uik-dashboard-hero__brand { font-family: var(--font-display); font-weight: 800; font-size: 18px; letter-spacing: -0.02em; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.uik-dashboard-hero__brand::before { content: ""; width: 12px; height: 12px; background: var(--lime); clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.uik-dashboard-hero__nav { display: flex; flex-direction: column; gap: 2px; }
.uik-dashboard-hero__nav-item { padding: 6px 10px; border-radius: 6px; color: var(--slate-300); display: flex; align-items: center; gap: 8px; font-size: 12.5px; cursor: default; }
.uik-dashboard-hero__nav-item.is-active { background: rgba(198,242,78,0.14); color: var(--lime); }
.uik-dashboard-hero__nav-item::before { content: ""; width: 14px; height: 14px; background: currentColor; opacity: 0.7; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.uik-dashboard-hero__main { padding: 18px; display: flex; flex-direction: column; gap: 14px; background: var(--bg-soft); }
.uik-dashboard-hero__topbar { display: flex; justify-content: space-between; align-items: center; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.uik-dashboard-hero__title { font-family: var(--font-display); font-weight: 700; font-size: 18px; }
.uik-dashboard-hero__user { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--fg-soft); }
.uik-dashboard-hero__user::after { content: ""; width: 26px; height: 26px; background: var(--coral); border-radius: 50%; }
.uik-dashboard-hero__kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.uik-dashboard-hero__kpi { background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 10px 12px; }
.uik-dashboard-hero__kpi-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-mute); }
.uik-dashboard-hero__kpi-value { font-family: var(--font-display); font-weight: 800; font-size: 20px; letter-spacing: -0.02em; line-height: 1.2; }
.uik-dashboard-hero__kpi-delta { font-size: 11px; color: #2BA84A; }
.uik-dashboard-hero__chart { background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 14px; min-height: 140px; display: flex; flex-direction: column; gap: 10px; }
.uik-dashboard-hero__chart-bars { display: flex; gap: 4px; align-items: flex-end; height: 80px; }
.uik-dashboard-hero__chart-bars span { flex: 1; background: linear-gradient(0deg, var(--lime-deep), var(--lime)); border-radius: 2px 2px 0 0; animation: dashbar 1.4s var(--ease-out) backwards; }
@keyframes dashbar { from { height: 0 !important; } }
.uik-dashboard-hero__activity { background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 12px; }
.uik-dashboard-hero__activity h6 { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); margin: 0 0 6px; }
.uik-dashboard-hero__activity ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; font-size: 12px; }
.uik-dashboard-hero__activity li::before { content: "▸"; color: var(--lime-deep); margin-right: 6px; }
@container (max-width: 640px) { .uik-dashboard-hero { grid-template-columns: 1fr; } .uik-dashboard-hero__sidebar { flex-direction: row; flex-wrap: wrap; padding: 10px; gap: 6px; } .uik-dashboard-hero__nav { flex-direction: row; flex-wrap: wrap; } .uik-dashboard-hero__kpis { grid-template-columns: 1fr 1fr; } }

/* --- v5.2 Charts suite (5-in-1) --- */
.uik-charts-suite { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; container-type: inline-size; }
.uik-chart-mini { background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-md); padding: 14px; display: flex; flex-direction: column; gap: 8px; min-height: 130px; }
.uik-chart-mini__head { display: flex; justify-content: space-between; align-items: baseline; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-mute); }
.uik-chart-mini__value { font-family: var(--font-display); font-weight: 800; font-size: 22px; letter-spacing: -0.025em; }
.uik-chart-mini__viz { flex: 1; min-height: 60px; }
.uik-chart-line { width: 100%; height: 60px; }
.uik-chart-pie, .uik-chart-donut { width: 80px; height: 80px; }
.uik-chart-spark { width: 100%; height: 30px; }
.uik-chart-bars { display: flex; gap: 3px; align-items: flex-end; height: 60px; }
.uik-chart-bars span { flex: 1; background: var(--lime); border-radius: 2px 2px 0 0; }
@container (max-width: 640px) { .uik-charts-suite { grid-template-columns: 1fr 1fr; } }
@container (max-width: 380px) { .uik-charts-suite { grid-template-columns: 1fr; } }

/* --- v5.3 Cohort table --- */
.uik-cohort {
  border: 1px solid var(--line); border-radius: var(--r-md); padding: 14px; background: var(--bg);
  font-family: var(--font-mono); font-size: 11px;
}
.uik-cohort table { width: 100%; border-collapse: separate; border-spacing: 2px; }
.uik-cohort th { text-align: left; color: var(--fg-mute); letter-spacing: 0.06em; text-transform: uppercase; font-size: 9.5px; padding: 4px; }
.uik-cohort td { text-align: center; padding: 6px 4px; border-radius: 3px; color: var(--fg); font-weight: 500; }
.uik-cohort td[data-pct="100"] { background: var(--lime); color: var(--ink); }
.uik-cohort td[data-pct="80"] { background: color-mix(in srgb, var(--lime) 70%, var(--bg)); }
.uik-cohort td[data-pct="60"] { background: color-mix(in srgb, var(--lime) 45%, var(--bg)); }
.uik-cohort td[data-pct="40"] { background: color-mix(in srgb, var(--lime) 25%, var(--bg)); }
.uik-cohort td[data-pct="20"] { background: color-mix(in srgb, var(--coral) 25%, var(--bg)); }
.uik-cohort td[data-pct="0"] { background: var(--cream); color: var(--fg-mute); }

/* --- v5.4 Status page --- */
.uik-statuspage { border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); padding: 14px; }
.uik-statuspage__head { display: flex; justify-content: space-between; align-items: center; padding-bottom: 10px; margin-bottom: 10px; border-bottom: 1px solid var(--line); }
.uik-statuspage__head h4 { font-family: var(--font-display); font-weight: 700; font-size: 15px; margin: 0; }
.uik-statuspage__overall { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: #2BA84A; font-weight: 600; }
.uik-statuspage__overall::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: #2BA84A; box-shadow: 0 0 0 0 #2BA84A; animation: pulse 2s ease-out infinite; }
.uik-statuspage ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.uik-statuspage li { display: grid; grid-template-columns: auto 1fr auto; gap: 8px; align-items: center; padding: 6px 8px; border-radius: 4px; font-size: 12px; }
.uik-statuspage li:hover { background: var(--bg-soft); }
.uik-statuspage__dot { width: 8px; height: 8px; border-radius: 50%; }
.uik-statuspage__dot--ok { background: #2BA84A; }
.uik-statuspage__dot--warn { background: #FFD23F; }
.uik-statuspage__dot--ko { background: var(--coral); }
.uik-statuspage__uptime { font-family: var(--font-mono); font-size: 11px; color: var(--fg-mute); }

/* --- v5.5 Spreadsheet (Notion-like) --- */
.uik-spreadsheet { border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; background: var(--bg); }
.uik-spreadsheet__head { display: grid; grid-template-columns: 28px repeat(4, 1fr); background: var(--bg-soft); border-bottom: 2px solid var(--line); }
.uik-spreadsheet__head > div { padding: 8px 10px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-mute); border-right: 1px solid var(--line); display: flex; align-items: center; gap: 4px; }
.uik-spreadsheet__head > div::before { content: ""; width: 8px; height: 8px; background: var(--lime); clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); flex-shrink: 0; }
.uik-spreadsheet__head > div:first-child { font-size: 11px; }
.uik-spreadsheet__head > div:first-child::before { display: none; }
.uik-spreadsheet__row { display: grid; grid-template-columns: 28px repeat(4, 1fr); border-bottom: 1px solid var(--line); font-size: 13px; }
.uik-spreadsheet__row:last-child { border-bottom: 0; }
.uik-spreadsheet__row > div { padding: 8px 10px; border-right: 1px solid var(--line); }
.uik-spreadsheet__row > div:first-child { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); background: var(--bg-soft); }
.uik-spreadsheet__row.is-active > div:not(:first-child) { background: color-mix(in srgb, var(--lime) 18%, var(--bg)); }

/* --- v5.6 Gantt pro --- */
.uik-gantt-pro { border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); padding: 14px; container-type: inline-size; }
.uik-gantt-pro__head { display: grid; grid-template-columns: 140px repeat(8, 1fr); gap: 2px; padding-bottom: 6px; border-bottom: 1px solid var(--line); margin-bottom: 8px; }
.uik-gantt-pro__head > div { font-family: var(--font-mono); font-size: 9px; color: var(--fg-mute); letter-spacing: 0.04em; text-align: center; }
.uik-gantt-pro__head > div:first-child { text-align: left; font-size: 10px; }
.uik-gantt-pro__row { display: grid; grid-template-columns: 140px 1fr; gap: 8px; align-items: center; min-height: 28px; }
.uik-gantt-pro__row > .label { font-size: 12px; color: var(--fg); }
.uik-gantt-pro__bar { position: relative; height: 16px; background: var(--bg-soft); border-radius: 999px; }
.uik-gantt-pro__bar > span { position: absolute; height: 100%; background: linear-gradient(90deg, var(--lime), var(--lime-deep)); border-radius: inherit; box-shadow: inset 0 0 0 1px var(--lime-deep); }
.uik-gantt-pro__bar > span.is-coral { background: linear-gradient(90deg, var(--coral), color-mix(in srgb, var(--coral) 80%, var(--ink))); }
.uik-gantt-pro__bar > span.is-ink { background: linear-gradient(90deg, var(--ink-2), var(--ink)); color: var(--paper); }
.uik-gantt-pro__milestone { position: absolute; top: 50%; transform: translate(-50%, -50%) rotate(45deg); width: 10px; height: 10px; background: var(--coral); }

/* --- v5.7 Onboarding wizard --- */
.uik-wizard { border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); padding: 18px; container-type: inline-size; }
.uik-wizard__progress { display: flex; gap: 4px; margin-bottom: 14px; }
.uik-wizard__progress span { flex: 1; height: 4px; border-radius: 2px; background: var(--line); }
.uik-wizard__progress span.is-done { background: var(--lime); }
.uik-wizard__progress span.is-current { background: linear-gradient(90deg, var(--lime), var(--line)); background-size: 200% 100%; animation: wizshimmer 1.4s linear infinite; }
@keyframes wizshimmer { to { background-position: 200% 0; } }
.uik-wizard__step { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 6px; }
.uik-wizard__title { font-family: var(--font-display); font-weight: 700; font-size: 18px; margin: 0 0 8px; }
.uik-wizard__body { color: var(--fg-soft); font-size: 13px; line-height: 1.5; margin-bottom: 14px; }
.uik-wizard__actions { display: flex; gap: 8px; justify-content: flex-end; }
.uik-wizard__btn { padding: 8px 14px; border-radius: var(--r-sm); font-size: 12.5px; font-weight: 600; }
.uik-wizard__btn--primary { background: var(--lime); color: var(--ink); }
.uik-wizard__btn--ghost { background: transparent; color: var(--fg-soft); }

/* --- v5.8 Cmd+K palette --- */
.uik-palette { background: var(--ink); color: var(--paper); border-radius: var(--r-md); border: 1px solid var(--ink-3); padding: 0; box-shadow: 0 24px 60px -8px rgba(0,0,0,0.6); max-width: 540px; container-type: inline-size; }
.uik-palette__input { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-bottom: 1px solid var(--ink-3); font-size: 14px; }
.uik-palette__input::before { content: "⌘"; color: var(--slate-400); font-family: var(--font-mono); font-weight: 600; font-size: 12px; padding: 2px 5px; border: 1px solid var(--ink-3); border-radius: 4px; }
.uik-palette__input span { color: var(--slate-300); flex: 1; }
.uik-palette__input span::after { content: "|"; color: var(--lime); animation: blink 1s steps(2) infinite; }
@keyframes blink { 50% { opacity: 0; } }
.uik-palette__group h6 { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate-400); padding: 8px 16px 4px; margin: 0; }
.uik-palette__item { display: grid; grid-template-columns: 22px 1fr auto; gap: 10px; align-items: center; padding: 8px 16px; cursor: pointer; }
.uik-palette__item:hover, .uik-palette__item.is-selected { background: rgba(198,242,78,0.10); }
.uik-palette__item.is-selected { color: var(--lime); }
.uik-palette__item-icon { width: 16px; height: 16px; background: currentColor; opacity: 0.7; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.uik-palette__item-shortcut { font-family: var(--font-mono); font-size: 10px; color: var(--slate-400); }

/* --- v5.9 Comments thread --- */
.uik-comments { display: flex; flex-direction: column; gap: 10px; }
.uik-comment { display: grid; grid-template-columns: 32px 1fr; gap: 10px; align-items: flex-start; }
.uik-comment__avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--lime); color: var(--ink); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 13px; }
.uik-comment__avatar.is-coral { background: var(--coral); color: var(--paper); }
.uik-comment__avatar.is-ink { background: var(--ink); color: var(--paper); }
.uik-comment__body { background: var(--bg-soft); border-radius: var(--r-md); padding: 10px 12px; font-size: 13px; }
.uik-comment__head { display: flex; gap: 8px; align-items: baseline; margin-bottom: 4px; }
.uik-comment__name { font-weight: 600; }
.uik-comment__time { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); }
.uik-comment__text { color: var(--fg); line-height: 1.4; }
.uik-comment__text mark { background: rgba(198,242,78,0.4); padding: 0 2px; border-radius: 2px; }
.uik-comment__reactions { display: flex; gap: 4px; margin-top: 6px; }
.uik-comment__reactions span { padding: 2px 8px; background: var(--bg); border: 1px solid var(--line); border-radius: 999px; font-size: 11px; display: inline-flex; gap: 4px; align-items: center; }
.uik-comment__reactions span.is-active { background: rgba(198,242,78,0.18); border-color: var(--lime); }
.uik-comment.is-reply { margin-left: 42px; }

/* --- v5.10 Document collaboration (live cursors) --- */
.uik-doc-collab { position: relative; background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-md); padding: 24px; min-height: 200px; }
.uik-doc-collab__title { font-family: var(--font-display); font-weight: 700; font-size: 20px; margin-bottom: 8px; }
.uik-doc-collab__line { height: 8px; background: var(--cream); border-radius: 4px; margin-bottom: 8px; }
.uik-doc-collab__line.is-short { width: 60%; }
.uik-doc-collab__line.is-medium { width: 80%; }
.uik-doc-collab__cursor { position: absolute; pointer-events: none; }
.uik-doc-collab__cursor::before { content: ""; display: block; width: 2px; height: 16px; background: var(--lime); margin-bottom: 2px; animation: blink 1s steps(2) infinite; }
.uik-doc-collab__cursor::after { content: attr(data-name); display: block; padding: 2px 6px; background: var(--lime); color: var(--ink); font-family: var(--font-mono); font-size: 9px; font-weight: 600; border-radius: 3px; white-space: nowrap; }
.uik-doc-collab__cursor.is-coral::before, .uik-doc-collab__cursor.is-coral::after { background: var(--coral); color: var(--paper); }
.uik-doc-collab__cursor.is-ink::before, .uik-doc-collab__cursor.is-ink::after { background: var(--ink); color: var(--paper); }

/* --- v5.11 Feedback widget --- */
.uik-feedback { border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); padding: 16px; max-width: 320px; }
.uik-feedback h4 { font-family: var(--font-display); font-weight: 700; font-size: 15px; margin: 0 0 10px; }
.uik-feedback__emojis { display: flex; gap: 6px; margin-bottom: 10px; }
.uik-feedback__emoji { width: 36px; height: 36px; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); background: var(--cream); display: flex; align-items: center; justify-content: center; font-size: 18px; cursor: pointer; transition: background var(--dur-fast) var(--ease); }
.uik-feedback__emoji:hover { background: var(--lime); }
.uik-feedback__emoji.is-selected { background: var(--lime); }
.uik-feedback textarea { width: 100%; border: 1px solid var(--line); border-radius: var(--r-sm); padding: 8px; font-size: 12px; min-height: 60px; resize: vertical; }

/* --- v5.12 Knowledge graph --- */
.uik-knowledge-graph { width: 100%; aspect-ratio: 1.4 / 1; container-type: inline-size; }
.uik-knowledge-graph svg { width: 100%; height: 100%; }
.uik-knowledge-graph .node { fill: var(--cream); stroke: var(--ink); stroke-width: 1.5; }
.uik-knowledge-graph .node--center { fill: var(--lime); }
.uik-knowledge-graph .edge { stroke: var(--ink); stroke-width: 1; stroke-dasharray: 2 3; opacity: 0.4; animation: edge-flow 3s linear infinite; }
@keyframes edge-flow { to { stroke-dashoffset: -20; } }
.uik-knowledge-graph text { font-family: var(--font-mono); font-size: 9px; fill: var(--fg); }

/* --- v5.13 Pulse globe --- */
.uik-pulse-globe { position: relative; width: 100%; aspect-ratio: 1; max-width: 360px; margin-inline: auto; }
.uik-pulse-globe svg { width: 100%; height: 100%; }
.uik-pulse-globe circle.pulse { fill: var(--lime); transform-origin: center; }
.uik-pulse-globe circle.pulse-bg { fill: var(--lime); opacity: 0.3; transform-origin: center; animation: globe-pulse 2.4s ease-out infinite; }
@keyframes globe-pulse { 0% { r: 4; opacity: 0.6; } 100% { r: 14; opacity: 0; } }

/* --- v5.14 Team roster --- */
.uik-team { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; container-type: inline-size; }
.uik-team__member { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 10px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--bg); position: relative; text-align: center; }
.uik-team__avatar { width: 44px; height: 44px; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); background: var(--cream); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--ink); }
.uik-team__avatar.is-lime { background: var(--lime); }
.uik-team__avatar.is-coral { background: var(--coral); color: var(--paper); }
.uik-team__avatar.is-ink { background: var(--ink); color: var(--paper); }
.uik-team__name { font-weight: 600; font-size: 12px; }
.uik-team__role { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); }
.uik-team__status { width: 8px; height: 8px; border-radius: 50%; position: absolute; top: 8px; right: 8px; }
.uik-team__status--online { background: #2BA84A; box-shadow: 0 0 0 2px var(--bg); }
.uik-team__status--away { background: #FFD23F; box-shadow: 0 0 0 2px var(--bg); }
.uik-team__status--offline { background: var(--mist-2); box-shadow: 0 0 0 2px var(--bg); }
@container (max-width: 640px) { .uik-team { grid-template-columns: repeat(3, 1fr); } }
@container (max-width: 380px) { .uik-team { grid-template-columns: 1fr 1fr; } }

/* --- v5.15 Roadmap board --- */
.uik-roadmap { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; container-type: inline-size; }
.uik-roadmap__col { background: var(--bg-soft); border: 1px solid var(--line); border-radius: var(--r-md); padding: 10px; display: flex; flex-direction: column; gap: 8px; min-height: 200px; }
.uik-roadmap__col h5 { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); margin: 0 0 4px; padding-bottom: 4px; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; }
.uik-roadmap__card { background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 8px; font-size: 12px; display: flex; flex-direction: column; gap: 4px; }
.uik-roadmap__card-title { font-weight: 600; }
.uik-roadmap__card-meta { display: flex; gap: 4px; flex-wrap: wrap; }
.uik-roadmap__chip { font-family: var(--font-mono); font-size: 9px; padding: 1px 6px; border-radius: 999px; }
.uik-roadmap__chip.is-ai { background: var(--lime); color: var(--ink); }
.uik-roadmap__chip.is-new { background: var(--coral); color: var(--paper); }
.uik-roadmap__chip.is-default { background: var(--cream); color: var(--fg-mute); }
@container (max-width: 720px) { .uik-roadmap { grid-template-columns: 1fr 1fr; } }
@container (max-width: 380px) { .uik-roadmap { grid-template-columns: 1fr; } }

/* --- v5.16 Announce banner --- */
.uik-announce { display: flex; align-items: center; gap: 10px; background: var(--ink); color: var(--paper); padding: 10px 14px; border-radius: var(--r-md); border: 1px solid var(--ink-3); font-size: 13px; }
.uik-announce__chip { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 8px; background: var(--lime); color: var(--ink); border-radius: 999px; font-weight: 600; }
.uik-announce__cta { margin-left: auto; color: var(--lime); font-weight: 600; }
.uik-announce__close { color: var(--slate-400); font-size: 16px; cursor: pointer; }

/* --- v5.17 Comparison grid --- */
.uik-compgrid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; font-size: 13px; }
.uik-compgrid > div { padding: 10px 12px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.uik-compgrid > div:nth-child(4n) { border-right: 0; }
.uik-compgrid__head { background: var(--bg-soft); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); }
.uik-compgrid__head--hexio { background: var(--lime); color: var(--ink); font-weight: 700; }
.uik-compgrid__cell--feature { font-weight: 500; }
.uik-compgrid__cell--check { color: #2BA84A; font-size: 16px; text-align: center; }
.uik-compgrid__cell--x { color: var(--coral); font-size: 16px; text-align: center; }
.uik-compgrid__cell--partial { color: #B07A00; text-align: center; font-size: 12px; }

/* --- v5.18 Customer quotes marquee --- */
.uik-quotes-marquee { overflow: hidden; padding: var(--s-3) 0; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.uik-quotes-marquee__track { display: flex; gap: var(--s-4); animation: quotes-flow 40s linear infinite; }
@keyframes quotes-flow { to { transform: translateX(-50%); } }
.uik-quotes-marquee:hover .uik-quotes-marquee__track { animation-play-state: paused; }
.uik-quote-card { display: flex; gap: 10px; align-items: flex-start; padding: 14px; background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-md); min-width: 320px; max-width: 380px; flex-shrink: 0; }
.uik-quote-card__avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--cream); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; }
.uik-quote-card__body { font-size: 13px; line-height: 1.5; }
.uik-quote-card__stars { color: var(--lime-deep); font-size: 11px; margin-top: 6px; }
.uik-quote-card__role { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); margin-top: 2px; }

/* --- v5.19 Stats counter strip --- */
.uik-stats-counter { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); container-type: inline-size; }
.uik-stat { padding: var(--s-4); border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); display: flex; flex-direction: column; gap: 6px; position: relative; overflow: hidden; }
.uik-stat::before { content: ""; position: absolute; right: -10px; top: -10px; width: 50px; height: 50px; background: var(--lime); opacity: 0.10; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.uik-stat__value { font-family: var(--font-display); font-weight: 800; font-size: clamp(28px, 4vw, 44px); letter-spacing: -0.025em; line-height: 1; }
.uik-stat__label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); }
.uik-stat__sub { font-size: 12px; color: var(--fg-soft); }
@container (max-width: 640px) { .uik-stats-counter { grid-template-columns: 1fr 1fr; } }
@container (max-width: 380px) { .uik-stats-counter { grid-template-columns: 1fr; } }

/* --- v5.20 Form multi-step --- */
.uik-mform { border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); padding: 18px; container-type: inline-size; }
.uik-mform__steps { display: flex; gap: 4px; margin-bottom: 16px; align-items: center; }
.uik-mform__step { display: flex; flex-direction: column; align-items: center; gap: 4px; flex: 0 0 auto; min-width: 70px; }
.uik-mform__step-dot { width: 24px; height: 24px; border-radius: 50%; background: var(--line-strong); color: var(--bg); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-weight: 600; font-size: 11px; }
.uik-mform__step.is-done .uik-mform__step-dot { background: var(--lime); color: var(--ink); }
.uik-mform__step.is-current .uik-mform__step-dot { background: var(--ink); color: var(--paper); box-shadow: 0 0 0 3px rgba(11,15,25,0.16); }
.uik-mform__step-label { font-family: var(--font-mono); font-size: 9.5px; color: var(--fg-mute); letter-spacing: 0.06em; text-transform: uppercase; }
.uik-mform__step-bar { flex: 1; height: 2px; background: var(--line); border-radius: 1px; align-self: center; margin-top: 11px; }
.uik-mform__step.is-done + .uik-mform__step-bar { background: var(--lime); }
.uik-mform__field { margin-bottom: 12px; }
.uik-mform__field label { font-size: 12px; font-weight: 500; color: var(--fg); display: block; margin-bottom: 4px; }
.uik-mform__field input, .uik-mform__field select { width: 100%; border: 1px solid var(--line); border-radius: var(--r-sm); padding: 8px 10px; font-size: 13px; }
.uik-mform__actions { display: flex; gap: 8px; justify-content: space-between; margin-top: 14px; }

/* ===== v5 reduced-motion overrides ===== */
@media (prefers-reduced-motion: reduce) {
  .uik-dashboard-hero__chart-bars span,
  .uik-statuspage__overall::before,
  .uik-doc-collab__cursor::before,
  .uik-pulse-globe circle.pulse-bg,
  .uik-knowledge-graph .edge,
  .uik-quotes-marquee__track,
  .uik-wizard__progress span.is-current,
  .uik-palette__input span::after { animation: none !important; }
  .uik-feedback__emoji,
  .uik-team__member,
  .uik-roadmap__card,
  .uik-quote-card { transition: none !important; }
}

/* ===================================================
   v6 components — més èpics: timeline, activity feed,
   permissions, integrations status, etc
   =================================================== */

/* Timeline vertical with milestones */
.uik-timeline { position: relative; padding-left: 28px; }
.uik-timeline::before { content: ""; position: absolute; left: 9px; top: 0; bottom: 0; width: 2px; background: var(--line); }
.uik-timeline__entry { position: relative; padding-bottom: 18px; }
.uik-timeline__entry::before { content: ""; position: absolute; left: -24px; top: 4px; width: 14px; height: 14px; background: var(--lime); clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.uik-timeline__entry.is-pending::before { background: var(--cream-2); }
.uik-timeline__date { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); }
.uik-timeline__title { font-weight: 600; font-size: 14px; margin: 4px 0 2px; }
.uik-timeline__desc { font-size: 12px; color: var(--fg-soft); }

/* Activity feed (live) */
.uik-activity { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; background: var(--bg); }
.uik-activity__item { display: grid; grid-template-columns: 32px 1fr auto; gap: 10px; align-items: center; padding: 10px 14px; border-bottom: 1px solid var(--line); font-size: 13px; }
.uik-activity__item:last-child { border-bottom: 0; }
.uik-activity__item:hover { background: var(--bg-soft); }
.uik-activity__avatar { width: 28px; height: 28px; border-radius: 50%; background: var(--cream); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 11px; }
.uik-activity__text { color: var(--fg); }
.uik-activity__text strong { color: var(--ink); }
.uik-activity__text mark { background: rgba(198,242,78,0.4); padding: 0 3px; border-radius: 2px; }
.uik-activity__time { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); }

/* Permissions matrix */
.uik-perm-matrix { border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; background: var(--bg); }
.uik-perm-matrix table { width: 100%; border-collapse: collapse; font-size: 12px; }
.uik-perm-matrix th, .uik-perm-matrix td { padding: 8px 10px; border-bottom: 1px solid var(--line); border-right: 1px solid var(--line); text-align: center; }
.uik-perm-matrix th:first-child, .uik-perm-matrix td:first-child { text-align: left; font-weight: 500; }
.uik-perm-matrix thead th { background: var(--bg-soft); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-mute); }
.uik-perm-matrix .perm--full { background: rgba(198,242,78,0.18); color: var(--lime-deep); font-weight: 600; }
.uik-perm-matrix .perm--read { background: var(--cream); color: var(--fg-soft); }
.uik-perm-matrix .perm--none { color: var(--fg-mute); }

/* Integration status grid */
.uik-integ-status { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 8px; }
.uik-integ-status__cell { padding: 12px; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--bg); display: flex; flex-direction: column; gap: 6px; min-width: 0; overflow: hidden; }
.uik-integ-status__head { display: flex; justify-content: space-between; align-items: center; gap: 8px; min-width: 0; }
.uik-integ-status__name { font-weight: 600; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; flex: 1; }
.uik-integ-status__dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.uik-integ-status__dot.is-ok { background: #2BA84A; box-shadow: 0 0 6px rgba(43,168,74,0.5); }
.uik-integ-status__dot.is-warn { background: #FFD23F; }
.uik-integ-status__dot.is-ko { background: var(--coral); }
.uik-integ-status__sub { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Vertical KPI hero (stats with hexagon halo) */
.uik-kpi-hex { position: relative; text-align: center; padding: 20px; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--bg); overflow: hidden; }
.uik-kpi-hex::before { content: ""; position: absolute; right: -20px; top: -20px; width: 80px; height: 80px; background: var(--lime); opacity: 0.10; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.uik-kpi-hex__value { font-family: var(--font-display); font-weight: 800; font-size: 48px; letter-spacing: -0.03em; line-height: 1; }
.uik-kpi-hex__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); margin-top: 4px; }
.uik-kpi-hex__trend { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; color: #2BA84A; margin-top: 6px; }

/* Mobile/tablet device frames */
.uik-device-stack { position: relative; display: flex; gap: -40px; align-items: center; justify-content: center; }
.uik-device-laptop { width: 100%; max-width: 420px; aspect-ratio: 16/10; background: var(--ink); border: 8px solid var(--ink); border-radius: 12px 12px 4px 4px; padding: 4px; position: relative; }
.uik-device-laptop::after { content: ""; position: absolute; left: 50%; bottom: -6px; transform: translateX(-50%); width: 60%; height: 4px; background: var(--ink-3); border-radius: 0 0 8px 8px; }
.uik-device-laptop__screen { background: var(--bg); border-radius: 4px; height: 100%; padding: 8px; font-size: 9px; overflow: hidden; }

/* Code block (monospace with syntax highlighting) */
.uik-code { background: var(--ink); color: var(--paper); padding: 14px 16px; border-radius: var(--r-md); font-family: var(--font-mono); font-size: 12px; line-height: 1.6; overflow-x: auto; position: relative; }
.uik-code::before { content: ""; position: absolute; top: 8px; right: 12px; width: 12px; height: 12px; background: #FF6B4A; border-radius: 50%; box-shadow: 18px 0 0 #FFD23F, 36px 0 0 #3CCB7F; }
.uik-code__line { display: block; }
.uik-code__line .k { color: var(--coral); }
.uik-code__line .s { color: var(--lime); }
.uik-code__line .c { color: var(--slate-400); font-style: italic; }
.uik-code__line .n { color: var(--paper); }
.uik-code__line .b { color: #FFD23F; }

/* Notification dropdown */
.uik-notif-dropdown { background: var(--bg); border: 1px solid var(--line-strong); border-radius: var(--r-md); box-shadow: 0 24px 48px -16px rgba(11,15,25,0.18); width: 360px; max-width: 100%; overflow: hidden; }
.uik-notif-dropdown__head { padding: 12px 14px; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; }
.uik-notif-dropdown__head h5 { font-family: var(--font-display); font-weight: 700; font-size: 14px; margin: 0; }
.uik-notif-dropdown__head button { font-size: 11px; color: var(--fg-soft); }
.uik-notif-dropdown__item { padding: 10px 14px; display: grid; grid-template-columns: 8px 1fr; gap: 10px; border-bottom: 1px solid var(--line); font-size: 12.5px; }
.uik-notif-dropdown__item:last-child { border-bottom: 0; }
.uik-notif-dropdown__item.is-unread { background: rgba(198,242,78,0.06); }
.uik-notif-dropdown__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lime); margin-top: 6px; align-self: start; }
.uik-notif-dropdown__item.is-read .uik-notif-dropdown__dot { background: transparent; }

/* Module switcher (segmented control) */
.uik-segmented { display: inline-flex; padding: 3px; background: var(--bg-soft); border-radius: var(--r-pill); gap: 2px; }
.uik-segmented button { padding: 8px 14px; border-radius: var(--r-pill); font-size: 12.5px; font-weight: 500; color: var(--fg-soft); cursor: pointer; }
.uik-segmented button.is-active { background: var(--ink); color: var(--paper); }

/* Tags input */
.uik-tags-input { border: 1px solid var(--line); border-radius: var(--r-md); padding: 6px 10px; display: flex; flex-wrap: wrap; gap: 6px; background: var(--bg); }
.uik-tag { display: inline-flex; align-items: center; gap: 4px; padding: 3px 8px; background: var(--cream); border-radius: var(--r-pill); font-size: 12px; }
.uik-tag.is-lime { background: var(--lime); color: var(--ink); }
.uik-tag__remove { color: var(--fg-mute); cursor: pointer; }

/* Avatars stack (overlapping) */
.uik-avatars-stack { display: inline-flex; }
.uik-avatars-stack > * { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--bg); margin-left: -8px; background: var(--cream); color: var(--ink); font-family: var(--font-display); font-weight: 700; font-size: 11px; display: flex; align-items: center; justify-content: center; }
.uik-avatars-stack > *:first-child { margin-left: 0; }
.uik-avatars-stack__more { background: var(--ink); color: var(--paper); }

/* ===== v6 reduced-motion overrides ===== */
@media (prefers-reduced-motion: reduce) {
  .uik-integ-status__dot.is-ok { box-shadow: none !important; }
}


/* ===================================================
   v7 components — modals, sidebars, banners, etc
   =================================================== */

/* Modal dialog */
.uik-modal { background: var(--bg); border-radius: var(--r-lg); border: 1px solid var(--line-strong); box-shadow: 0 32px 80px -16px rgba(11,15,25,0.4); width: 480px; max-width: 92vw; padding: 24px; position: relative; }
.uik-modal__head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 14px; }
.uik-modal__title { font-family: var(--font-display); font-weight: 700; font-size: 20px; margin: 0; }
.uik-modal__close { color: var(--fg-mute); font-size: 18px; cursor: pointer; width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border-radius: 50%; }
.uik-modal__close:hover { background: var(--bg-soft); color: var(--fg); }
.uik-modal__body { font-size: 14px; color: var(--fg-soft); line-height: 1.5; }
.uik-modal__actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 20px; }

/* Inline alert */
.uik-alert { display: flex; gap: 12px; padding: 12px 14px; border-radius: var(--r-md); border: 1px solid var(--line); align-items: flex-start; font-size: 13px; }
.uik-alert--info { background: color-mix(in srgb, var(--lime) 8%, var(--bg)); border-color: color-mix(in srgb, var(--lime) 40%, var(--line)); }
.uik-alert--warn { background: color-mix(in srgb, #FFD23F 12%, var(--bg)); border-color: color-mix(in srgb, #FFD23F 50%, var(--line)); }
.uik-alert--error { background: color-mix(in srgb, var(--coral) 8%, var(--bg)); border-color: color-mix(in srgb, var(--coral) 40%, var(--line)); }
.uik-alert__icon { flex-shrink: 0; width: 20px; height: 20px; }
.uik-alert__title { font-weight: 600; margin-bottom: 2px; }

/* Empty state */
.uik-empty { text-align: center; padding: 40px 20px; }
.uik-empty__icon { width: 64px; height: 64px; margin: 0 auto 16px; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); background: var(--cream); display: flex; align-items: center; justify-content: center; color: var(--fg-mute); }
.uik-empty__title { font-family: var(--font-display); font-weight: 700; font-size: 18px; margin: 0 0 6px; }
.uik-empty__sub { font-size: 13px; color: var(--fg-soft); max-width: 320px; margin: 0 auto; }
.uik-empty__cta { margin-top: 16px; }

/* Filter bar */
.uik-filter-bar { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; padding: 10px 14px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); }
.uik-filter { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: var(--bg-soft); border-radius: var(--r-pill); font-size: 12.5px; font-family: var(--font-mono); color: var(--fg-soft); cursor: pointer; }
.uik-filter.is-active { background: var(--ink); color: var(--paper); }
.uik-filter__x { font-size: 14px; }

/* Toggle switch */
.uik-toggle { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; }
.uik-toggle__track { width: 36px; height: 20px; border-radius: 10px; background: var(--mist-2); position: relative; transition: background var(--dur-fast) var(--ease); }
.uik-toggle__track::after { content: ""; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: var(--paper); box-shadow: 0 1px 3px rgba(0,0,0,0.15); transition: left var(--dur-fast) var(--ease); }
.uik-toggle.is-on .uik-toggle__track { background: var(--lime); }
.uik-toggle.is-on .uik-toggle__track::after { left: 18px; background: var(--ink); }
.uik-toggle__label { font-size: 13px; }

/* Breadcrumb */
.uik-breadcrumb { display: flex; gap: 8px; align-items: center; font-size: 12.5px; color: var(--fg-mute); font-family: var(--font-mono); }
.uik-breadcrumb a { color: var(--fg-soft); }
.uik-breadcrumb a:hover { color: var(--fg); }
.uik-breadcrumb__sep { color: var(--mist-2); }
.uik-breadcrumb__current { color: var(--fg); font-weight: 600; }

/* Sidebar nav */
.uik-sidebar { background: var(--ink); color: var(--paper); padding: 16px; border-radius: var(--r-lg); width: 220px; }
.uik-sidebar__brand { font-family: var(--font-display); font-weight: 800; font-size: 18px; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.uik-sidebar__group { margin-bottom: 14px; }
.uik-sidebar__group-title { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate-400); margin-bottom: 6px; }
.uik-sidebar__item { display: flex; align-items: center; gap: 8px; padding: 6px 10px; border-radius: 6px; color: var(--slate-300); font-size: 12.5px; cursor: pointer; }
.uik-sidebar__item:hover { background: rgba(255,255,255,0.05); color: var(--paper); }
.uik-sidebar__item.is-active { background: rgba(198,242,78,0.14); color: var(--lime); }
.uik-sidebar__item-icon { width: 14px; height: 14px; background: currentColor; opacity: 0.7; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }

/* Big CTA card with hex backdrop */
.uik-cta-hex { padding: 32px; background: var(--ink); color: var(--paper); border-radius: var(--r-xl); position: relative; overflow: hidden; }
.uik-cta-hex::before { content: ""; position: absolute; right: -40px; top: -40px; width: 200px; height: 200px; background: var(--lime); opacity: 0.15; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.uik-cta-hex h3 { font-family: var(--font-display); font-weight: 800; font-size: 28px; margin: 0 0 12px; letter-spacing: -0.02em; }
.uik-cta-hex p { color: var(--slate-300); font-size: 15px; margin: 0 0 20px; line-height: 1.5; max-width: 540px; }
.uik-cta-hex .btn { background: var(--lime); color: var(--ink); }

/* Webhook log entry */
.uik-webhook-log { font-family: var(--font-mono); font-size: 11.5px; background: var(--bg); border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; }
.uik-webhook-log__row { display: grid; grid-template-columns: auto 1fr auto auto; gap: 10px; padding: 8px 12px; border-bottom: 1px solid var(--line); align-items: center; }
.uik-webhook-log__row:last-child { border-bottom: 0; }
.uik-webhook-log__time { color: var(--fg-mute); }
.uik-webhook-log__method { padding: 2px 6px; border-radius: 3px; font-size: 9.5px; font-weight: 600; }
.uik-webhook-log__method--post { background: rgba(198,242,78,0.18); color: var(--lime-deep); }
.uik-webhook-log__method--get { background: var(--cream); }
.uik-webhook-log__path { color: var(--fg); }
.uik-webhook-log__status { font-weight: 600; }
.uik-webhook-log__status--200 { color: #2BA84A; }
.uik-webhook-log__status--500 { color: var(--coral); }

/* Tier badge inline */
.uik-tier-badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: var(--r-pill); font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; }
.uik-tier-badge--pro { background: var(--lime); color: var(--ink); }
.uik-tier-badge--enterprise { background: var(--ink); color: var(--paper); }
.uik-tier-badge--starter { background: var(--cream); color: var(--fg-soft); }

/* Module activator chip (toggle on/off look) */
.uik-mod-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid var(--line); border-radius: var(--r-pill); background: var(--bg); font-size: 12.5px; cursor: pointer; transition: all var(--dur-fast) var(--ease); }
.uik-mod-chip.is-active { background: var(--lime); border-color: var(--lime); color: var(--ink); font-weight: 600; }
.uik-mod-chip__check { width: 14px; height: 14px; border-radius: 50%; background: var(--mist-2); flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 9px; }
.uik-mod-chip.is-active .uik-mod-chip__check { background: var(--ink); color: var(--lime); }
.uik-mod-chip.is-active .uik-mod-chip__check::after { content: "✓"; }

/* Reduced-motion v7 */
@media (prefers-reduced-motion: reduce) {
  .uik-toggle__track::after,
  .uik-mod-chip { transition: none !important; }
}

/* ===================================================
   v9 components — page enrichment specific
   =================================================== */

/* Attendance grid (monthly fitxatge heatmap) */
.uik-attendance-grid { border: 1px solid var(--line); border-radius: var(--r-md); padding: 14px; background: var(--bg); container-type: inline-size; }
.uik-attendance-grid__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--line); }
.uik-attendance-grid__head h5 { font-family: var(--font-display); font-weight: 700; font-size: 14px; margin: 0; }
.uik-attendance-grid__total { font-family: var(--font-mono); font-size: 12px; color: var(--fg-soft); }
.uik-attendance-grid__weekdays { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; margin-bottom: 4px; }
.uik-attendance-grid__weekdays span { font-family: var(--font-mono); font-size: 9px; color: var(--fg-mute); text-align: center; text-transform: uppercase; letter-spacing: 0.06em; }
.uik-attendance-grid__cells { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
.uik-attendance-grid__cell { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 10px; border-radius: 3px; background: var(--cream); color: var(--fg-soft); }
.uik-attendance-grid__cell[data-h="8"] { background: var(--lime); color: var(--ink); font-weight: 600; }
.uik-attendance-grid__cell[data-h="6"] { background: color-mix(in srgb, var(--lime) 70%, var(--bg)); }
.uik-attendance-grid__cell[data-h="4"] { background: color-mix(in srgb, var(--lime) 40%, var(--bg)); }
.uik-attendance-grid__cell[data-h="0"] { background: transparent; color: var(--fg-mute); }
.uik-attendance-grid__cell[data-h="off"] { background: var(--mist); color: var(--fg-mute); }
.uik-attendance-grid__legend { display: flex; gap: 6px; align-items: center; margin-top: 8px; font-family: var(--font-mono); font-size: 9.5px; color: var(--fg-mute); }
.uik-attendance-grid__legend-bar { display: flex; gap: 2px; }
.uik-attendance-grid__legend-bar span { width: 14px; height: 14px; border-radius: 2px; }

/* Customer 360 fitxa */
.uik-customer-360 { border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); overflow: hidden; container-type: inline-size; }
.uik-customer-360__head { padding: 16px; display: flex; gap: 12px; align-items: center; background: var(--bg-soft); border-bottom: 1px solid var(--line); }
.uik-customer-360__avatar { width: 48px; height: 48px; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); background: var(--lime); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--ink); flex-shrink: 0; }
.uik-customer-360__name { font-family: var(--font-display); font-weight: 700; font-size: 18px; }
.uik-customer-360__sub { font-family: var(--font-mono); font-size: 11px; color: var(--fg-mute); }
.uik-customer-360__stats { display: grid; grid-template-columns: repeat(4, 1fr); padding: 12px 0; border-bottom: 1px solid var(--line); }
.uik-customer-360__stat { padding: 4px 16px; border-right: 1px solid var(--line); display: flex; flex-direction: column; gap: 2px; }
.uik-customer-360__stat:last-child { border-right: 0; }
.uik-customer-360__stat-label { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-mute); }
.uik-customer-360__stat-value { font-family: var(--font-display); font-weight: 700; font-size: 16px; }
.uik-customer-360__timeline { padding: 12px 16px; }
.uik-customer-360__timeline h6 { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); margin: 0 0 8px; }
.uik-customer-360__timeline-item { display: grid; grid-template-columns: 60px 1fr; gap: 10px; padding: 6px 0; font-size: 12.5px; }
.uik-customer-360__timeline-item time { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); }
@container (max-width: 480px) { .uik-customer-360__stats { grid-template-columns: 1fr 1fr; } .uik-customer-360__stat:nth-child(2) { border-right: 0; } }

/* Export flow (AEAT) */
.uik-export-flow { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: 8px; align-items: center; padding: 14px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); container-type: inline-size; }
.uik-export-flow__node { padding: 10px 12px; background: var(--bg-soft); border: 1px solid var(--line); border-radius: var(--r-sm); text-align: center; font-size: 12px; }
.uik-export-flow__node.is-source { background: var(--cream); }
.uik-export-flow__node.is-target { background: var(--ink); color: var(--paper); }
.uik-export-flow__node h6 { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-mute); margin: 0 0 4px; }
.uik-export-flow__node.is-target h6 { color: var(--slate-400); }
.uik-export-flow__node-name { font-weight: 600; }
.uik-export-flow__arrow { color: var(--lime-deep); font-size: 18px; font-weight: 700; }
@container (max-width: 600px) { .uik-export-flow { grid-template-columns: 1fr; } .uik-export-flow__arrow { transform: rotate(90deg); justify-self: center; } }

/* Revenue board (financial dashboard for CFO) */
.uik-revenue-board { display: grid; grid-template-columns: 2fr 1fr; gap: 10px; container-type: inline-size; }
.uik-revenue-board__main { padding: 16px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); }
.uik-revenue-board__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px; }
.uik-revenue-board__head h5 { font-family: var(--font-display); font-weight: 700; font-size: 16px; margin: 0; }
.uik-revenue-board__period { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); }
.uik-revenue-board__big { font-family: var(--font-display); font-weight: 800; font-size: 36px; letter-spacing: -0.025em; line-height: 1; }
.uik-revenue-board__delta { color: #2BA84A; font-size: 12px; margin-top: 4px; }
.uik-revenue-board__bars { display: flex; gap: 3px; align-items: flex-end; height: 60px; margin-top: 12px; }
.uik-revenue-board__bars span { flex: 1; background: linear-gradient(0deg, var(--lime-deep), var(--lime)); border-radius: 2px 2px 0 0; }
.uik-revenue-board__side { display: flex; flex-direction: column; gap: 8px; }
.uik-revenue-board__side-card { padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); font-size: 12px; }
.uik-revenue-board__side-card-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-mute); }
.uik-revenue-board__side-card-value { font-family: var(--font-display); font-weight: 700; font-size: 18px; margin-top: 2px; }
@container (max-width: 540px) { .uik-revenue-board { grid-template-columns: 1fr; } }

/* Tax deadline countdown card */
.uik-tax-deadline { padding: 18px; border-radius: var(--r-md); background: var(--ink); color: var(--paper); position: relative; overflow: hidden; }
.uik-tax-deadline::before { content: ""; position: absolute; right: -30px; top: -30px; width: 100px; height: 100px; background: var(--lime); opacity: 0.12; clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); }
.uik-tax-deadline__chip { display: inline-flex; align-items: center; gap: 4px; padding: 3px 8px; background: rgba(198,242,78,0.16); border-radius: 999px; font-family: var(--font-mono); font-size: 10px; font-weight: 600; color: var(--lime); margin-bottom: 8px; }
.uik-tax-deadline__model { font-family: var(--font-display); font-weight: 700; font-size: 22px; margin: 0; }
.uik-tax-deadline__period { font-family: var(--font-mono); font-size: 11px; color: var(--slate-400); }
.uik-tax-deadline__countdown { display: flex; gap: 12px; margin: 14px 0; }
.uik-tax-deadline__digit { background: rgba(255,255,255,0.06); border-radius: 6px; padding: 8px 12px; min-width: 50px; text-align: center; }
.uik-tax-deadline__digit-value { font-family: var(--font-display); font-weight: 800; font-size: 24px; }
.uik-tax-deadline__digit-label { font-family: var(--font-mono); font-size: 9.5px; color: var(--slate-400); text-transform: uppercase; letter-spacing: 0.06em; }
.uik-tax-deadline__btn { display: inline-block; padding: 8px 14px; background: var(--lime); color: var(--ink); border-radius: 999px; font-size: 12px; font-weight: 600; }

/* Meeting card */
.uik-meeting-card { padding: 16px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg); container-type: inline-size; }
.uik-meeting-card__head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; }
.uik-meeting-card__title { font-family: var(--font-display); font-weight: 700; font-size: 15px; margin: 0; }
.uik-meeting-card__time { font-family: var(--font-mono); font-size: 11px; color: var(--fg-soft); margin-top: 2px; }
.uik-meeting-card__chip { font-family: var(--font-mono); font-size: 10px; padding: 2px 8px; background: var(--lime); color: var(--ink); border-radius: 999px; font-weight: 600; }
.uik-meeting-card__attendees { display: flex; gap: 4px; margin-bottom: 10px; }
.uik-meeting-card__attendees > span { width: 26px; height: 26px; border-radius: 50%; border: 2px solid var(--bg); margin-left: -6px; background: var(--cream); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 10px; color: var(--ink); }
.uik-meeting-card__attendees > span:first-child { margin-left: 0; }
.uik-meeting-card__notes { background: var(--bg-soft); border-radius: var(--r-sm); padding: 10px; font-size: 12px; }
.uik-meeting-card__notes h6 { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-mute); margin: 0 0 6px; }
.uik-meeting-card__notes ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.uik-meeting-card__notes li { padding-left: 12px; position: relative; }
.uik-meeting-card__notes li::before { content: "▸"; position: absolute; left: 0; color: var(--lime-deep); }

/* ---------- Preventive overflow fixes for narrow grid columns (320-480px) ---------- */
/* Wide tables: enable horizontal scroll instead of squashing columns */
.uik-spreadsheet { overflow-x: auto; }
.uik-spreadsheet__head,
.uik-spreadsheet__row { min-width: 480px; }

.uik-compgrid { overflow-x: auto; }
.uik-perm-matrix { overflow-x: auto; }

/* Webhook log: break long URLs cleanly */
.uik-webhook-log { container-type: inline-size; }
.uik-webhook-log__path,
.uik-webhook-log__url { word-break: break-all; min-width: 0; }

/* Pipeline: collapse 4 cols → 2 → 1 in narrow containers */
.uik-pipeline { container-type: inline-size; }
@container (max-width: 480px) {
  .uik-pipeline__cols { grid-template-columns: repeat(2, 1fr); }
}
@container (max-width: 320px) {
  .uik-pipeline__cols { grid-template-columns: 1fr; }
}

/* Time tracker: keep heatmap minimum width so cells stay tappable */
.uik-time { container-type: inline-size; }
.uik-time__heatmap { min-width: 280px; }

