/* ── Portfolio Hero ── */
.portfolio-hero {
  padding: 150px 0 80px;
  background: linear-gradient(135deg, #0c1a1a 0%, #0f2b2b 50%, #0a2525 100%) !important;
  background-color: #0c1a1a !important;
  color: #fff !important;
}

.portfolio-hero h1 {
  font-size: 2.8rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 1rem;
}

.portfolio-hero .hero-sub {
  color: rgba(255,255,255,0.6);
  font-size: 1.05rem;
}

@media (max-width: 768px) {
  .portfolio-hero {
    padding: 120px 0 40px;
  }
  .portfolio-hero h1 {
    font-size: 2rem;
  }
}

/* ── Filter Bar ── */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}

.filter-btn {
  background: transparent;
  border: 1.5px solid var(--border);
  border-radius: 50px;
  padding: 8px 20px;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.3s;
  font-family: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

.filter-btn:hover {
  border-color: var(--primary);
  color: var(--primary);
}

.filter-btn.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

/* ── Project Card ── */
.project-card {
  background: #fff;
  border-radius: 20px;
  border: 1px solid var(--border);
  overflow: hidden;
  transition: box-shadow 0.4s;
}

.project-card:hover {
  box-shadow: var(--shadow-lg);
}

/* ── Mockup Browser Frame ── */
.mockup-wrap {
  padding: 2rem;
  background: var(--surface);
  height: 100%;
  display: flex;
  align-items: center;
}

.browser-frame {
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,0.12);
  border: 1px solid var(--border);
  background: #fff;
}

.browser-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: #f1f3f5;
  border-bottom: 1px solid var(--border);
}

.browser-dots {
  display: flex;
  gap: 6px;
}

.browser-dots span,
.b-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

.browser-dots span:nth-child(1),
.b-dot:nth-child(1) { background: #ff5f57; }
.browser-dots span:nth-child(2),
.b-dot:nth-child(2) { background: #febc2e; }
.browser-dots span:nth-child(3),
.b-dot:nth-child(3) { background: #28c840; }

.browser-url,
.b-url {
  flex: 1;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 4px 12px;
  font-size: 0.72rem;
  color: var(--text-muted);
  font-family: monospace;
}

.browser-body {
  height: 400px;
  overflow: hidden;
}

@media (max-width: 992px) {
  .mockup-wrap {
    padding: 1rem;
  }
  .browser-body {
    height: 400px;
    transform: scale(0.75);
    transform-origin: top left;
    width: 133.33%;
  }
  .browser-frame {
    max-height: calc(400px * 0.75 + 40px);
    overflow: hidden;
  }
}

@media (max-width: 768px) {
  .browser-body {
    transform: scale(0.6);
    width: 166.67%;
  }
  .browser-frame {
    max-height: calc(400px * 0.6 + 40px);
  }
}

@media (max-width: 576px) {
  .mockup-wrap {
    padding: 0.75rem;
  }
  .browser-body {
    transform: scale(0.5);
    width: 200%;
  }
  .browser-frame {
    max-height: calc(400px * 0.5 + 36px);
  }
  .browser-bar {
    padding: 6px 10px;
    gap: 8px;
  }
  .b-dot,
  .browser-dots span {
    width: 7px;
    height: 7px;
  }
  .browser-url,
  .b-url {
    font-size: 0.6rem;
    padding: 3px 8px;
  }
}

/* ── Mock App UI ── */
.mock-app {
  display: flex;
  height: 100%;
  font-family: 'Inter', sans-serif;
}

.mock-sidebar {
  width: 52px;
  background: #0f172a;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px 0;
  gap: 4px;
  flex-shrink: 0;
  overflow: hidden;
}

/* Sidebar con etichette testuali */
.mock-sidebar.wide {
  width: 110px;
  align-items: stretch;
  padding: 12px 8px;
}

.mock-sidebar.wide .mock-sidebar-brand {
  align-self: center;
  margin-bottom: 12px;
}

.mock-sidebar.wide .mock-nav-item {
  width: auto;
  height: auto;
  padding: 7px 8px;
  gap: 6px;
  flex-direction: row;
  justify-content: flex-start;
}

.mock-nav-item span {
  font-size: 0.62rem;
  font-weight: 600;
  color: rgba(255,255,255,0.35);
  white-space: nowrap;
}

.mock-nav-item.active span {
  color: var(--primary-light);
}

.mock-sidebar-brand {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: #fff;
  font-size: 0.65rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}

.mock-nav-item {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.35);
  font-size: 0.9rem;
  transition: all 0.2s;
}

.mock-nav-item.active {
  background: rgba(255,255,255,0.1);
  color: var(--primary-light);
}

.mock-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: #f8fafc;
  min-width: 0;
}

.mock-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  background: #fff;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.mock-page-title,
.mock-topbar-title {
  font-weight: 700;
  font-size: 0.82rem;
  color: var(--text);
}

.mock-topbar-user {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 3px 10px;
}

.mock-ai-badge {
  background: linear-gradient(135deg, rgba(13,148,136,0.1), rgba(14,165,233,0.1));
  color: var(--primary);
  font-size: 0.6rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 3px;
}

.mock-avatar {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-size: 0.55rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── Stats ── */
.mock-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  padding: 12px 16px;
  flex-shrink: 0;
}


.mock-stat-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
}

.mock-stat-label {
  font-size: 0.55rem;
  color: var(--text-muted);
  font-weight: 500;
  margin-bottom: 2px;
}

.mock-stat-value {
  font-size: 1.1rem;
  font-weight: 800;
  color: var(--text);
  line-height: 1.2;
}

.mock-stat-value.warn {
  color: #ef4444;
}

.mock-stat-trend {
  font-size: 0.5rem;
  color: var(--text-muted);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: 2px;
}

.mock-stat-trend.up {
  color: #10b981;
}

/* ── Chart + Table Row ── */
.mock-content-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 0 16px 12px;
  flex: 1;
  min-height: 0;
}


.mock-chart-card,
.mock-table-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  overflow: hidden;
}

.mock-card-header {
  font-size: 0.62rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mock-badge-warn {
  background: #fef2f2;
  color: #ef4444;
  font-size: 0.5rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 10px;
}

/* ── Bar Chart ── */
.mock-chart {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  height: 80px;
  padding-bottom: 4px;
}

.mock-bar {
  flex: 1;
  background: rgba(13,148,136,0.15);
  border-radius: 3px 3px 0 0;
  transition: background 0.3s;
  min-height: 8px;
}

.mock-bar.active {
  background: var(--primary);
}

.mock-chart-labels {
  display: flex;
  justify-content: space-around;
  font-size: 0.45rem;
  color: var(--text-muted);
  margin-top: 4px;
}

/* ── Table Rows ── */
.mock-table-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px solid #f1f5f9;
}

.mock-table-row:last-child {
  border-bottom: none;
}

.mock-lot-name {
  font-size: 0.58rem;
  font-weight: 500;
  color: var(--text);
}

.mock-lot-date {
  font-size: 0.52rem;
  font-weight: 600;
  color: var(--text-muted);
  padding: 2px 8px;
  border-radius: 10px;
  background: #f1f5f9;
}

.mock-lot-date.danger {
  background: #fef2f2;
  color: #ef4444;
}

.mock-lot-date.warn {
  background: #fffbeb;
  color: #f59e0b;
}

/* ── AI Bar ── */
.mock-ai-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: linear-gradient(90deg, rgba(13,148,136,0.06), rgba(14,165,233,0.06));
  border-top: 1px solid rgba(13,148,136,0.1);
  font-size: 0.55rem;
  color: var(--primary-dark);
  flex-shrink: 0;
}

.mock-ai-bar i {
  color: var(--primary);
  font-size: 0.7rem;
}

/* ── Project Info ── */
.project-info {
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}

@media (max-width: 992px) {
  .project-info {
    padding: 2rem 1.5rem;
  }
}

.project-sector {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--primary);
  margin-bottom: 1rem;
}

.project-info h2 {
  font-size: 1.6rem;
  font-weight: 800;
  margin-bottom: 0.8rem;
  letter-spacing: -0.02em;
}

.project-desc {
  font-size: 0.92rem;
  color: var(--text-muted);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}

.project-features {
  margin-bottom: 1.5rem;
}

.project-feat {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  color: var(--text);
  padding: 5px 0;
}

.project-feat i {
  color: #10b981;
  font-size: 0.9rem;
}

.project-feat.ai {
  color: var(--primary);
  font-weight: 500;
}

.project-feat.ai i {
  color: var(--primary);
}

.project-meta {
  display: flex;
  gap: 24px;
  margin-bottom: 1.5rem;
  padding: 1rem 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.meta-item {
  display: flex;
  flex-direction: column;
}

.meta-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  margin-bottom: 2px;
}

.meta-value {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text);
}

/* ═══════════════════════════════════════════════════
   TYPE B: Calendar / Booking Mockup
   ═══════════════════════════════════════════════════ */

.mock-calendar-wrap {
  display: flex;
  flex: 1;
  overflow: hidden;
  min-height: 0;
  overflow: hidden;
}

.mock-cal-sidebar {
  width: 120px;
  background: #fff;
  border-right: 1px solid var(--border);
  padding: 8px;
  flex-shrink: 0;
  overflow: hidden;
}

.mock-cal-sidebar-title {
  font-size: 0.55rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.mock-cal-client {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 4px 6px;
  border-radius: 5px;
  margin-bottom: 3px;
  font-size: 0.5rem;
  color: var(--text);
  font-weight: 500;
}

.mock-cal-client:nth-child(odd) {
  background: #f8fafc;
}

.mock-cal-client-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.mock-cal-grid {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.mock-cal-header {
  display: grid;
  grid-template-columns: 28px repeat(6, 1fr);
  gap: 1px;
  background: #fff;
  border-bottom: 1px solid var(--border);
}

.mock-cal-day-label {
  font-size: 0.48rem;
  font-weight: 700;
  color: var(--text-muted);
  text-align: center;
  padding: 6px 2px;
}

.mock-cal-day-label.today {
  color: var(--primary);
  background: rgba(13,148,136,0.06);
  border-radius: 4px;
}

.mock-cal-body {
  display: grid;
  grid-template-columns: 28px repeat(6, 1fr);
  gap: 1px;
  flex: 1;
  overflow: hidden;
  background: #fff;
  padding: 2px;
  align-content: start;
}

.mock-cal-time {
  font-size: 0.42rem;
  color: var(--text-muted);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 2px;
  font-weight: 500;
}

.mock-cal-cell {
  border: 1px solid #f1f5f9;
  border-radius: 3px;
  position: relative;
  min-height: 0;
  overflow: hidden;
}

.mock-cal-event {
  position: absolute;
  inset: 1px;
  border-radius: 3px;
  padding: 2px 4px;
  font-size: 0.42rem;
  font-weight: 600;
  color: #fff;
  overflow: hidden;
  line-height: 1.2;
}

.mock-cal-event.ev-teal { background: var(--primary); }
.mock-cal-event.ev-blue { background: var(--accent); }
.mock-cal-event.ev-orange { background: #f59e0b; }
.mock-cal-event.ev-purple { background: #8b5cf6; }
.mock-cal-event.ev-rose { background: #f43f5e; }
.mock-cal-event.ev-emerald { background: #10b981; }
.mock-cal-event.ev-slate { background: #64748b; }


/* ═══════════════════════════════════════════════════
   TYPE C: Table / List Mockup
   ═══════════════════════════════════════════════════ */

.mock-filter-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px;
  flex-shrink: 0;
}

.mock-search-box {
  display: flex;
  align-items: center;
  gap: 4px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 0.52rem;
  color: var(--text-muted);
  flex: 1;
  max-width: 160px;
}

.mock-search-box i {
  font-size: 0.6rem;
}

.mock-filter-chip {
  display: flex;
  align-items: center;
  gap: 3px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 3px 8px;
  font-size: 0.5rem;
  font-weight: 600;
  color: var(--text-muted);
}

.mock-filter-chip.active {
  background: rgba(13,148,136,0.1);
  border-color: var(--primary);
  color: var(--primary);
}

.mock-filter-chip i {
  font-size: 0.5rem;
}

.mock-data-table {
  flex: 1;
  padding: 0 16px 8px;
  overflow: hidden;
  min-height: 0;
}

.mock-data-thead {
  display: grid;
  gap: 0;
  padding: 6px 10px;
  background: #f8fafc;
  border-radius: 6px;
  margin-bottom: 4px;
}

.mock-data-thead span {
  font-size: 0.48rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
}

.mock-data-row {
  display: grid;
  gap: 0;
  padding: 7px 10px;
  border-bottom: 1px solid #f1f5f9;
  align-items: center;
}

.mock-data-row span {
  font-size: 0.52rem;
  font-weight: 500;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mock-data-row span.muted {
  color: var(--text-muted);
}

.mock-status-badge {
  display: inline-flex;
  padding: 2px 6px;
  border-radius: 10px;
  font-size: 0.46rem;
  font-weight: 700;
}

.mock-status-badge.success {
  background: #ecfdf5;
  color: #059669;
}

.mock-status-badge.warning {
  background: #fffbeb;
  color: #d97706;
}

.mock-status-badge.danger {
  background: #fef2f2;
  color: #dc2626;
}

.mock-status-badge.info {
  background: #eff6ff;
  color: #2563eb;
}

.mock-status-badge.neutral {
  background: #f1f5f9;
  color: #64748b;
}

/* ═══════════════════════════════════════════════════
   TYPE D: Kanban Mockup
   ═══════════════════════════════════════════════════ */

.mock-kanban-wrap {
  display: flex;
  gap: 8px;
  padding: 12px 16px;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.mock-kanban-col {
  flex: 1;
  background: #f1f5f9;
  border-radius: 8px;
  padding: 8px;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
}

.mock-kanban-col-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  flex-shrink: 0;
}

.mock-kanban-col-title {
  font-size: 0.55rem;
  font-weight: 700;
  color: var(--text);
}

.mock-kanban-count {
  font-size: 0.45rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 10px;
  background: rgba(0,0,0,0.06);
  color: var(--text-muted);
}

.mock-kanban-cards {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.mock-kanban-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px;
  flex-shrink: 0;
}

.mock-kanban-card-title {
  font-size: 0.52rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 3px;
  line-height: 1.3;
}

.mock-kanban-card-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.44rem;
  color: var(--text-muted);
}

.mock-kanban-card-tag {
  display: inline-flex;
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 0.42rem;
  font-weight: 600;
}

.mock-kanban-card-tag.tag-teal { background: rgba(13,148,136,0.12); color: var(--primary); }
.mock-kanban-card-tag.tag-blue { background: rgba(14,165,233,0.12); color: var(--accent); }
.mock-kanban-card-tag.tag-orange { background: rgba(245,158,11,0.12); color: #d97706; }
.mock-kanban-card-tag.tag-purple { background: rgba(139,92,246,0.12); color: #7c3aed; }
.mock-kanban-card-tag.tag-rose { background: rgba(244,63,94,0.12); color: #e11d48; }
.mock-kanban-card-tag.tag-emerald { background: rgba(16,185,129,0.12); color: #059669; }

.mock-kanban-card-priority {
  width: 4px;
  height: 4px;
  border-radius: 50%;
}
.mock-kanban-card-priority.high { background: #ef4444; }
.mock-kanban-card-priority.medium { background: #f59e0b; }
.mock-kanban-card-priority.low { background: #10b981; }

/* ═══════════════════════════════════════════════════
   TYPE E: Catalog / Grid Mockup
   ═══════════════════════════════════════════════════ */

.mock-catalog-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 16px;
  flex-shrink: 0;
}

.mock-catalog-count {
  font-size: 0.52rem;
  color: var(--text-muted);
  font-weight: 500;
}

.mock-catalog-view-btns {
  display: flex;
  gap: 3px;
}

.mock-catalog-view-btn {
  width: 22px;
  height: 22px;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.55rem;
  color: var(--text-muted);
}

.mock-catalog-view-btn.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

.mock-catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 0 16px 12px;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}


.mock-catalog-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}

.mock-catalog-thumb {
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  color: rgba(255,255,255,0.85);
}

.mock-catalog-thumb.thumb-teal { background: linear-gradient(135deg, #0d9488, #2dd4bf); }
.mock-catalog-thumb.thumb-blue { background: linear-gradient(135deg, #0ea5e9, #38bdf8); }
.mock-catalog-thumb.thumb-orange { background: linear-gradient(135deg, #f59e0b, #fbbf24); }
.mock-catalog-thumb.thumb-purple { background: linear-gradient(135deg, #8b5cf6, #a78bfa); }
.mock-catalog-thumb.thumb-rose { background: linear-gradient(135deg, #f43f5e, #fb7185); }
.mock-catalog-thumb.thumb-emerald { background: linear-gradient(135deg, #10b981, #34d399); }
.mock-catalog-thumb.thumb-slate { background: linear-gradient(135deg, #475569, #94a3b8); }
.mock-catalog-thumb.thumb-amber { background: linear-gradient(135deg, #d97706, #fbbf24); }
.mock-catalog-thumb.thumb-indigo { background: linear-gradient(135deg, #4f46e5, #818cf8); }

.mock-catalog-info {
  padding: 6px 8px;
}

.mock-catalog-name {
  font-size: 0.52rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 1px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mock-catalog-detail {
  font-size: 0.44rem;
  color: var(--text-muted);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.mock-catalog-price {
  font-weight: 700;
  color: var(--primary);
}

.mock-catalog-stock {
  font-size: 0.42rem;
  font-weight: 600;
}

.mock-catalog-stock.in-stock { color: #059669; }
.mock-catalog-stock.low-stock { color: #d97706; }
.mock-catalog-stock.out-stock { color: #dc2626; }

/* ═══════════════════════════════════════════════════
   TYPE F — Master-Detail / CRM Split View
   ═══════════════════════════════════════════════════ */
.mock-split {
  display: flex;
  flex: 1;
  overflow: hidden;
  min-height: 0;
}

.mock-split-list {
  width: 38%;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  flex-shrink: 0;
}

.mock-split-list-header {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.mock-split-list-header .mock-search-box {
  flex: 1;
}

.mock-split-list-items {
  flex: 1;
  overflow: hidden;
}

.mock-split-item {
  padding: 8px 10px;
  border-bottom: 1px solid #f1f5f9;
  cursor: pointer;
  transition: background 0.15s;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.mock-split-item.active {
  background: rgba(13,148,136,0.06);
  border-left: 3px solid var(--primary);
}

.mock-split-item-name {
  font-size: 0.56rem;
  font-weight: 700;
  color: var(--text);
}

.mock-split-item-sub {
  font-size: 0.44rem;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 6px;
}

.mock-split-item-badge {
  display: inline-flex;
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 0.38rem;
  font-weight: 700;
}

.mock-split-item-badge.active { background: rgba(16,185,129,0.1); color: #059669; }
.mock-split-item-badge.expiring { background: rgba(245,158,11,0.1); color: #d97706; }
.mock-split-item-badge.expired { background: rgba(239,68,68,0.1); color: #dc2626; }

.mock-split-detail {
  flex: 1;
  padding: 12px 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mock-split-detail-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mock-split-detail-name {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--text);
}

.mock-split-detail-status {
  font-size: 0.44rem;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 20px;
  background: rgba(16,185,129,0.1);
  color: #059669;
}

.mock-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}

.mock-detail-field {
  background: #f8fafc;
  border: 1px solid #f1f5f9;
  border-radius: 6px;
  padding: 6px 8px;
}

.mock-detail-field-label {
  font-size: 0.38rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--text-muted);
  margin-bottom: 1px;
}

.mock-detail-field-value {
  font-size: 0.56rem;
  font-weight: 700;
  color: var(--text);
}

.mock-detail-section-title {
  font-size: 0.48rem;
  font-weight: 700;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 2px;
}

.mock-detail-mini-chart {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  height: 32px;
}

.mock-detail-mini-bar {
  flex: 1;
  background: var(--primary);
  border-radius: 2px 2px 0 0;
  opacity: 0.7;
  min-width: 0;
}

.mock-detail-mini-bar.highlight {
  opacity: 1;
  background: linear-gradient(180deg, var(--primary), var(--primary-dark));
}

.mock-detail-mini-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.32rem;
  color: var(--text-muted);
}


/* ═══════════════════════════════════════════════════
   TYPE G — Pipeline / Process Flow
   ═══════════════════════════════════════════════════ */
.mock-pipeline {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 10px 14px;
  gap: 8px;
  overflow: hidden;
}

.mock-pipeline-steps {
  display: flex;
  gap: 3px;
  flex-shrink: 0;
}

.mock-pipeline-step {
  flex: 1;
  text-align: center;
  padding: 6px 4px;
  border-radius: 6px;
  font-size: 0.44rem;
  font-weight: 700;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.mock-pipeline-step .step-icon {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.5rem;
  color: #fff;
}

.mock-pipeline-step .step-label {
  color: var(--text);
  font-size: 0.4rem;
}

.mock-pipeline-step .step-count {
  font-size: 0.65rem;
  font-weight: 800;
  color: var(--text);
}

.mock-pipeline-step::after {
  content: '→';
  position: absolute;
  right: -8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.5rem;
  color: var(--border);
  font-weight: 400;
}

.mock-pipeline-step:last-child::after {
  display: none;
}

.mock-pipeline-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  flex: 1;
  overflow: hidden;
  align-content: start;
}

.mock-pipeline-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  border-left: 3px solid var(--primary);
}

.mock-pipeline-card-title {
  font-size: 0.52rem;
  font-weight: 700;
  color: var(--text);
}

.mock-pipeline-card-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.42rem;
}

.mock-pipeline-card-label {
  color: var(--text-muted);
}

.mock-pipeline-card-value {
  font-weight: 700;
  color: var(--text);
}

.mock-pipeline-card-badge {
  display: inline-flex;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 0.38rem;
  font-weight: 700;
}

.mock-pipeline-card-badge.stage-1 { background: rgba(100,116,139,0.1); color: #475569; }
.mock-pipeline-card-badge.stage-2 { background: rgba(14,165,233,0.1); color: #0284c7; }
.mock-pipeline-card-badge.stage-3 { background: rgba(245,158,11,0.1); color: #d97706; }
.mock-pipeline-card-badge.stage-4 { background: rgba(16,185,129,0.1); color: #059669; }
