/* ==========================================================================
 * Emma Mason Campaign 6 Dashboard
 * Clean responsive rebuild.
 *
 * Regla principal:
 * - NO usar width:100vw en el dashboard.
 * - Ensanchar el contenedor del contenido de WordPress con :has().
 * - El dashboard vive dentro de ese contenedor y usa width:100%.
 * ========================================================================== */

/* ==========================================================================
 * 0) Twenty Twenty-Five / WP constrained layout fix
 * ========================================================================== */

body:has(.emma-c6-wrap) .wp-block-post-content,
body:has(.emma-c6-wrap) .entry-content {
  width: min(1240px, calc(100vw - 48px)) !important;
  max-width: min(1240px, calc(100vw - 48px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

body:has(.emma-c6-wrap) .wp-block-post-content > .emma-c6-wrap,
body:has(.emma-c6-wrap) .entry-content > .emma-c6-wrap {
  max-width: 100% !important;
}

/* ==========================================================================
 * 1) Main wrapper
 * ========================================================================== */

.emma-c6-wrap {
  width: 100% !important;
  max-width: 100% !important;

  margin: 24px auto 48px !important;
  padding: 0 !important;

  position: static !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;

  font-family: inherit;
  color: #111827;

  overflow-x: clip;
}

.emma-c6-wrap * {
  box-sizing: border-box;
}

/* ==========================================================================
 * 2) Topbar
 * ========================================================================== */

.emma-c6-wrap .yupy-topbar {
  position: sticky;
  top: 0;
  z-index: 50;

  width: 100%;
  max-width: 100%;

  background: #0b1220;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.emma-c6-wrap .yupy-topbar-inner {
  width: 100%;
  max-width: 100%;

  padding: 10px 14px;

  display: flex;
  align-items: center;
  gap: 12px;
}

.emma-c6-wrap .yupy-brand {
  display: flex;
  align-items: baseline;
  gap: 8px;

  color: #fff;
  min-width: 170px;
  flex: 0 0 auto;
}

.emma-c6-wrap .yupy-brand-dot {
  width: 10px;
  height: 10px;
  border-radius: 10px;
  background: #22c55e;
  display: inline-block;
  flex: 0 0 auto;
}

.emma-c6-wrap .yupy-brand-name {
  font-weight: 900;
  letter-spacing: .3px;
  line-height: 1.05;
  white-space: nowrap;
}

.emma-c6-wrap .yupy-brand-sub {
  opacity: .72;
  font-size: 12px;
  white-space: nowrap;
}

.emma-c6-wrap .yupy-nav-toggle {
  display: none;
  margin-left: auto;

  background: transparent;
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;

  padding: 7px 11px;
  border-radius: 10px;
  cursor: pointer;
}

.emma-c6-wrap .yupy-nav-slot {
  margin-left: auto;
  min-width: 0;
  flex: 1 1 auto;
}

.emma-c6-wrap .yupy-nav.yupy-nav--grouped {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;

  width: 100%;
  min-width: 0;
}

.emma-c6-wrap .yupy-nav-item {
  color: rgba(255,255,255,.86);
  text-decoration: none;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  min-height: 40px;
  padding: 9px 12px;

  border-radius: 10px;
  font-size: 13px;
  line-height: 1.2;
  white-space: nowrap;

  background: transparent;
  border: 0;
  cursor: pointer;
}

.emma-c6-wrap .yupy-nav-item:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
}

.emma-c6-wrap .yupy-nav-item.is-active,
.emma-c6-wrap .yupy-nav-group.is-active > .yupy-nav-group-toggle {
  background: rgba(255,255,255,.14);
  color: #fff;
}

.emma-c6-wrap .yupy-nav-spacer {
  flex: 1 1 auto;
  min-width: 12px;
}

.emma-c6-wrap .yupy-nav-group {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.emma-c6-wrap .yupy-nav-caret {
  font-size: 11px;
  opacity: .78;
  transform: translateY(1px);
}

.emma-c6-wrap .yupy-nav-dropdown {
  display: none;

  position: absolute;
  top: calc(100% + 8px);
  left: 0;

  min-width: 250px;
  padding: 8px;

  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.1);
  background: #111827;
  box-shadow: 0 18px 44px rgba(0,0,0,.28);

  z-index: 1000;
}

.emma-c6-wrap .yupy-nav-dropdown::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -8px;
  height: 8px;
}

.emma-c6-wrap .yupy-nav-group:hover .yupy-nav-dropdown,
.emma-c6-wrap .yupy-nav-group:focus-within .yupy-nav-dropdown {
  display: grid;
  gap: 4px;
}

.emma-c6-wrap .yupy-nav-dropdown-item {
  display: flex;
  align-items: center;

  padding: 10px 12px;
  border-radius: 10px;

  color: rgba(255,255,255,.86);
  text-decoration: none;
  font-size: 13px;
  line-height: 1.25;
  white-space: nowrap;
}

.emma-c6-wrap .yupy-nav-dropdown-item:hover,
.emma-c6-wrap .yupy-nav-dropdown-item.is-active {
  background: rgba(255,255,255,.14);
  color: #fff;
}

/* ==========================================================================
 * 3) Content
 * ========================================================================== */

.emma-c6-wrap .yupy-container {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 24px 24px 48px;
}

.emma-c6-wrap .yupy-content {
  margin-top: 16px;
  display: grid;
  gap: 16px;
}

.emma-c6-wrap .emma-c6-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.emma-c6-wrap .yupy-h2 {
  margin: 0;
  font-size: 24px;
  line-height: 1.15;
}

.emma-c6-wrap .yupy-h3 {
  margin: 0;
  font-size: 16px;
  line-height: 1.25;
}

.emma-c6-wrap .yupy-muted {
  color: rgba(15,23,42,.68);
  margin: 6px 0 12px;
}

.emma-c6-wrap .yupy-pill {
  display: inline-flex;
  align-items: center;

  border: 1px solid rgba(0,0,0,.1);
  padding: 6px 10px;
  border-radius: 999px;

  font-size: 12px;
  background: #fff;
  color: #334155;
}

/* ==========================================================================
 * 4) Cards / hero / KPIs
 * ========================================================================== */

.emma-c6-wrap .yupy-card {
  background: #fff;
  color: #1d2327;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  box-shadow: 0 6px 18px rgba(0,0,0,.05);
  overflow: hidden;
}

.emma-c6-wrap .yupy-card-error {
  border-color: rgba(220,38,38,.25);
}

.emma-c6-wrap .yupy-card-head {
  padding: 16px 16px 0;
}

.emma-c6-wrap .yupy-card-body {
  padding: 16px;
}

.emma-c6-wrap .emma-c6-hero {
  border-radius: 18px;
  padding: 28px;
  background: linear-gradient(135deg, #0b74c9, #67d4e6);
  color: #07111f;
}

.emma-c6-wrap .emma-c6-hero h2 {
  margin: 0 0 8px;
  font-size: 30px;
  font-weight: 900;
  line-height: 1.1;
}

.emma-c6-wrap .emma-c6-hero p {
  margin: 0;
  font-weight: 650;
  font-size: 16px;
  line-height: 1.35;
}

.emma-c6-wrap .emma-c6-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.emma-c6-wrap .emma-c6-kpi {
  padding: 18px;
  min-width: 0;
}

.emma-c6-wrap .emma-c6-kpi-label {
  font-size: 12px;
  color: #64748b;
  font-weight: 800;
  margin-bottom: 9px;
  line-height: 1.25;
}

.emma-c6-wrap .emma-c6-kpi-value {
  font-size: clamp(24px, 2.3vw, 30px);
  font-weight: 950;
  color: #0f172a;
  line-height: 1.05;
}

.emma-c6-wrap .emma-c6-kpi-hint {
  margin-top: 9px;
  font-size: 12px;
  color: #64748b;
  line-height: 1.35;
}

.emma-c6-wrap .emma-c6-grid-2 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

/* ==========================================================================
 * 5) Tables
 * ========================================================================== */

.emma-c6-wrap .yupy-table-wrap {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;

  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.08);
}

.emma-c6-wrap .yupy-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 620px;
}

.emma-c6-wrap .yupy-table th,
.emma-c6-wrap .yupy-table td {
  padding: 10px 12px;
  border-bottom: 1px solid rgba(0,0,0,.06);
  text-align: left;
  font-size: 13px;
  vertical-align: top;
  line-height: 1.35;
}

.emma-c6-wrap .yupy-table th {
  background: rgba(0,0,0,.035);
  font-weight: 800;
}

.emma-c6-wrap .yupy-table tr:last-child td {
  border-bottom: 0;
}

.emma-c6-wrap .yupy-alert {
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(59,130,246,.08);
  border: 1px solid rgba(59,130,246,.18);
}

.emma-c6-wrap .yupy-alert-soft {
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.55);
}

.emma-c6-wrap .emma-c6-placeholder {
  border: 1px dashed rgba(0,0,0,.18);
  border-radius: 14px;
  padding: 18px;
  background: rgba(15,23,42,.03);
  font-weight: 800;
  color: #475569;
}

/* ==========================================================================
 * 6) Theme protection
 * ========================================================================== */

.emma-c6-wrap h1,
.emma-c6-wrap h2,
.emma-c6-wrap h3,
.emma-c6-wrap h4,
.emma-c6-wrap h5,
.emma-c6-wrap h6 {
  letter-spacing: normal !important;
  word-spacing: normal !important;
}

.emma-c6-wrap a {
  text-decoration-thickness: auto;
}

/* ==========================================================================
 * 7) Responsive
 * ========================================================================== */

@media (max-width: 1180px) {
  body:has(.emma-c6-wrap) .wp-block-post-content,
  body:has(.emma-c6-wrap) .entry-content {
    width: min(1000px, calc(100vw - 36px)) !important;
    max-width: min(1000px, calc(100vw - 36px)) !important;
  }

  .emma-c6-wrap .emma-c6-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .emma-c6-wrap .emma-c6-grid-2 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  body:has(.emma-c6-wrap) .wp-block-post-content,
  body:has(.emma-c6-wrap) .entry-content {
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
  }

  .emma-c6-wrap .yupy-topbar-inner {
    flex-wrap: wrap;
  }

  .emma-c6-wrap .yupy-nav-toggle {
    display: inline-flex;
  }

  .emma-c6-wrap .yupy-nav-slot {
    display: none;
    width: 100%;
    margin-left: 0;
  }

  .emma-c6-wrap .yupy-nav-slot.is-open {
    display: block;
  }

  .emma-c6-wrap .yupy-nav.yupy-nav--grouped {
    align-items: stretch;
    width: 100%;
    gap: 6px;
    flex-direction: column;
  }

  .emma-c6-wrap .yupy-nav-item {
    justify-content: flex-start;
    width: 100%;
  }

  .emma-c6-wrap .yupy-nav-spacer {
    display: none;
  }

  .emma-c6-wrap .yupy-nav-group {
    display: grid;
    width: 100%;
  }

  .emma-c6-wrap .yupy-nav-group-toggle {
    width: 100%;
    justify-content: space-between;
  }

  .emma-c6-wrap .yupy-nav-dropdown {
    position: static;
    display: grid;
    gap: 4px;

    min-width: 0;
    width: 100%;

    margin: 4px 0 8px;
    padding: 6px 6px 6px 14px;

    border-radius: 12px;
    background: rgba(255,255,255,.045);
    box-shadow: none;
  }

  .emma-c6-wrap .yupy-nav-dropdown::before {
    display: none;
  }
}

@media (max-width: 720px) {
  body:has(.emma-c6-wrap) .wp-block-post-content,
  body:has(.emma-c6-wrap) .entry-content {
    width: calc(100vw - 16px) !important;
    max-width: calc(100vw - 16px) !important;
  }

  .emma-c6-wrap .yupy-container {
    padding: 18px 12px 36px;
  }

  .emma-c6-wrap .emma-c6-kpi-grid {
    grid-template-columns: 1fr;
  }

  .emma-c6-wrap .emma-c6-hero {
    padding: 22px;
  }

  .emma-c6-wrap .emma-c6-hero h2 {
    font-size: 24px;
  }
}
/* ==========================================================================
 * PATCH — Emma Campaign 6 mobile overflow fix
 * ==========================================================================
 * En desktop dejamos lo actual.
 * En móvil dejamos de pelear con 100vw y usamos el ancho real del contenedor.
 * ========================================================================== */

@media (max-width: 720px) {
  html,
  body {
    overflow-x: hidden !important;
  }

  body:has(.emma-c6-wrap) .wp-site-blocks,
  body:has(.emma-c6-wrap) main,
  body:has(.emma-c6-wrap) .wp-block-group,
  body:has(.emma-c6-wrap) .wp-block-post-content,
  body:has(.emma-c6-wrap) .entry-content {
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  body:has(.emma-c6-wrap) .wp-block-post-content,
  body:has(.emma-c6-wrap) .entry-content {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .emma-c6-wrap {
    width: 100% !important;
    max-width: 100% !important;

    margin-left: 0 !important;
    margin-right: 0 !important;

    padding-left: 0 !important;
    padding-right: 0 !important;

    overflow-x: hidden !important;
  }

  .emma-c6-wrap .yupy-topbar {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  .emma-c6-wrap .yupy-topbar-inner,
  .emma-c6-wrap .yupy-container {
    width: 100% !important;
    max-width: 100% !important;

    margin-left: 0 !important;
    margin-right: 0 !important;

    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .emma-c6-wrap .yupy-topbar-inner {
    display: flex !important;
    flex-wrap: wrap !important;
  }

  .emma-c6-wrap .yupy-brand {
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }

  .emma-c6-wrap .yupy-brand-name {
    font-size: 17px !important;
    white-space: nowrap !important;
  }

  .emma-c6-wrap .yupy-brand-sub {
    font-size: 11px !important;
    white-space: nowrap !important;
  }

  .emma-c6-wrap .yupy-nav-toggle {
    display: inline-flex !important;
    flex: 0 0 auto !important;
    max-width: 72px !important;
  }

  .emma-c6-wrap .yupy-nav-slot {
    display: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    overflow: hidden !important;
  }

  .emma-c6-wrap .yupy-nav-slot.is-open {
    display: block !important;
  }

  .emma-c6-wrap .yupy-nav.yupy-nav--grouped {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;

    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 6px !important;
  }

  .emma-c6-wrap .yupy-nav-item,
  .emma-c6-wrap .yupy-nav-group,
  .emma-c6-wrap .yupy-nav-group-toggle,
  .emma-c6-wrap .yupy-nav-dropdown,
  .emma-c6-wrap .yupy-nav-dropdown-item {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .emma-c6-wrap .yupy-nav-dropdown {
    position: static !important;
    display: grid !important;
    box-shadow: none !important;
  }

  .emma-c6-wrap .emma-c6-page-header {
    display: block !important;
  }

  .emma-c6-wrap .yupy-h2 {
    font-size: 22px !important;
  }

  .emma-c6-wrap .yupy-muted {
    font-size: 15px !important;
    line-height: 1.35 !important;
    overflow-wrap: anywhere !important;
  }

  .emma-c6-wrap .yupy-pill {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .emma-c6-wrap .emma-c6-hero {
    padding: 20px !important;
    border-radius: 16px !important;
  }

  .emma-c6-wrap .emma-c6-hero h2 {
    font-size: 22px !important;
  }

  .emma-c6-wrap .emma-c6-hero p {
    font-size: 14px !important;
    line-height: 1.35 !important;
  }

  .emma-c6-wrap .emma-c6-kpi-grid {
    grid-template-columns: 1fr !important;
  }

  .emma-c6-wrap .emma-c6-grid-2 {
    grid-template-columns: 1fr !important;
  }

  .emma-c6-wrap .yupy-card {
    max-width: 100% !important;
  }

  .emma-c6-wrap .yupy-table-wrap {
    max-width: 100% !important;
    overflow-x: auto !important;
  }

  .emma-c6-wrap .yupy-table {
    min-width: 560px !important;
  }
}
/* ==========================================================================
 * Emma Campaign 6 — Regional Summary filters
 * ========================================================================== */

.emma-c6-filter-card {
  margin-bottom: 16px;
}

.emma-c6-filter-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  gap: 14px;
  align-items: start;
}

.emma-c6-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.emma-c6-label {
  font-size: 12px;
  color: #64748b;
  font-weight: 800;
}

.emma-c6-wrap .yupy-input {
  width: 100%;
  border: 1px solid rgba(0,0,0,.14);
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 13px;
  background: #fff;
  color: #0f172a;
}

.emma-c6-wrap select.yupy-input {
  min-height: 42px;
}

.emma-c6-wrap .emma-c6-multi {
  min-height: 148px;
}

.emma-c6-period-inline {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.emma-c6-period-box,
.emma-c6-geo-box {
  display: none;
}

.emma-c6-period-box.is-active,
.emma-c6-geo-box.is-active {
  display: flex;
}

div.emma-c6-period-box.is-active {
  display: block;
}

.emma-c6-filter-actions {
  margin-top: 16px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.emma-c6-btn-primary,
.emma-c6-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
}

.emma-c6-btn-primary {
  background: #111827;
  color: #fff;
  border: 0;
}

.emma-c6-btn-secondary {
  background: #fff;
  color: #111827;
  border: 1px solid rgba(0,0,0,.14);
}

.emma-c6-kpi-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 1180px) {
  .emma-c6-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .emma-c6-kpi-grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .emma-c6-filter-grid {
    grid-template-columns: 1fr;
  }

  .emma-c6-period-inline {
    grid-template-columns: 1fr;
  }

  .emma-c6-kpi-grid-3 {
    grid-template-columns: 1fr;
  }

  .emma-c6-filter-actions {
    display: grid;
  }
}
/* ==========================================================================
 * Emma Campaign 6 — Checkbox pills for seasons / years
 * ========================================================================== */

.emma-c6-check-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.emma-c6-check-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.emma-c6-check-grid-years {
  max-height: 180px;
  overflow-y: auto;
  padding: 2px;
}

.emma-c6-check-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;

  min-height: 40px;
  padding: 9px 11px;

  border: 1px solid rgba(0,0,0,.14);
  border-radius: 12px;
  background: #fff;

  font-size: 13px;
  font-weight: 800;
  color: #111827;

  cursor: pointer;
  user-select: none;
}

.emma-c6-check-pill input {
  width: 15px;
  height: 15px;
  margin: 0;
}

.emma-c6-check-pill:has(input:checked) {
  background: #111827;
  color: #fff;
  border-color: #111827;
}

@media (max-width: 720px) {
  .emma-c6-check-grid-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .emma-c6-check-grid-years {
    max-height: none;
  }

  .emma-c6-check-pill {
    width: 100%;
    justify-content: flex-start;
  }
}
/* ==========================================================================
 * Emma Campaign 6 — List pagination
 * ========================================================================== */

.emma-c6-list-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;

  margin: 0 0 14px;
  padding: 12px;

  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  background: rgba(15,23,42,.03);
}

.emma-c6-per-page-form {
  margin: 0;
}

.emma-c6-per-page-label {
  display: flex;
  align-items: center;
  gap: 8px;

  font-size: 13px;
  font-weight: 800;
  color: #334155;
}

.emma-c6-per-page-label select {
  width: auto !important;
  min-width: 90px;
}

.emma-c6-pagination-summary {
  font-size: 13px;
  color: #64748b;
  font-weight: 700;
}

.emma-c6-pagination {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.emma-c6-pagination a,
.emma-c6-pagination span {
  min-width: 34px;
  min-height: 34px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 7px 10px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.12);

  background: #fff;
  color: #111827;

  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
}

.emma-c6-pagination span.is-active {
  background: #111827;
  color: #fff;
  border-color: #111827;
}

.emma-c6-pagination span.is-disabled {
  opacity: .45;
  cursor: not-allowed;
}

.emma-c6-pagination span.is-ellipsis {
  border-color: transparent;
  background: transparent;
  min-width: auto;
}

@media (max-width: 720px) {
  .emma-c6-list-toolbar {
    align-items: stretch;
    display: grid;
  }

  .emma-c6-per-page-label {
    justify-content: space-between;
  }

  .emma-c6-pagination {
    justify-content: flex-start;
  }
}
/* ==========================================================================
 * People Like You — Overview progress
 * ========================================================================== */

.emma-c6-progress-card {
  margin-top: 16px;
  margin-bottom: 16px;
}

.emma-c6-progress-bars {
  display: grid;
  gap: 16px;
}

.emma-c6-progress-row {
  display: grid;
  gap: 8px;
}

.emma-c6-progress-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;

  font-size: 13px;
  color: #334155;
}

.emma-c6-progress-top strong {
  font-size: 14px;
  color: #0f172a;
}

.emma-c6-progress-top span {
  font-weight: 800;
  color: #475569;
}

.emma-c6-progress-track {
  width: 100%;
  height: 14px;

  overflow: hidden;
  border-radius: 999px;
  background: rgba(15, 23, 42, .10);
  border: 1px solid rgba(15, 23, 42, .08);
}

.emma-c6-progress-fill {
  height: 100%;
  min-width: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #147bd1, #5ccfe6);
}

.emma-c6-progress-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;

  margin-top: 18px;
}

.emma-c6-mini-kpi {
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(15, 23, 42, .035);
  border: 1px solid rgba(15, 23, 42, .07);
}

.emma-c6-mini-kpi span {
  display: block;
  margin-bottom: 5px;

  font-size: 12px;
  font-weight: 800;
  color: #64748b;
}

.emma-c6-mini-kpi strong {
  display: block;

  font-size: 20px;
  line-height: 1.1;
  color: #020617;
}

@media (max-width: 900px) {
  .emma-c6-progress-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .emma-c6-progress-kpis {
    grid-template-columns: 1fr;
  }

  .emma-c6-progress-top {
    align-items: flex-start;
  }
}

/* ==========================================================================
 * People Like You — visual cleanup / spacing pass
 * ========================================================================== */

/* ---------- Global spacing ---------- */

.emma-c6-wrap,
.emma-c6-overview {
  display: grid;
  gap: 24px;
}

.emma-c6-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.emma-c6-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

/* ---------- Top nav cleanup ---------- */
/* Ajusta si alguno no aplica, pero normalmente uno de estos selectores va a pegar */

.emma-c6-nav,
.emma-c6-topbar,
.emma-c6-menu-bar,
.emma-c6-header-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;

  min-height: 68px;
  padding: 14px 22px;

  border-radius: 16px;
  background: #041127;
}

.emma-c6-nav-left,
.emma-c6-topbar-left,
.emma-c6-brand-wrap {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.emma-c6-nav-center,
.emma-c6-topbar-center,
.emma-c6-menu-links {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.emma-c6-nav-right,
.emma-c6-topbar-right {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}

.emma-c6-nav a,
.emma-c6-topbar a,
.emma-c6-menu-bar a,
.emma-c6-header-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-height: 40px;
  padding: 10px 14px;

  border-radius: 12px;
  text-decoration: none;
}

.emma-c6-nav .is-active,
.emma-c6-topbar .is-active,
.emma-c6-menu-bar .is-active,
.emma-c6-header-nav .is-active {
  background: rgba(255,255,255,.10);
}

/* ---------- Intro / hero ---------- */

.emma-c6-hero {
  padding: 28px 28px 26px;
  border-radius: 22px;
  background: linear-gradient(90deg, #157fd6 0%, #63cbe1 100%);
  box-shadow: 0 12px 28px rgba(2, 6, 23, .08);
}

.emma-c6-hero h2 {
  margin: 0 0 10px;
  font-size: 28px;
  line-height: 1.1;
}

.emma-c6-hero p {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
  max-width: 920px;
}

/* ---------- KPI cards ---------- */

.emma-c6-kpi-card {
  padding: 20px 20px 18px;
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 6px 18px rgba(15, 23, 42, .04);
}

.emma-c6-kpi-label {
  margin-bottom: 10px;
  font-size: 13px;
  font-weight: 800;
  color: #64748b;
}

.emma-c6-kpi-value {
  margin-bottom: 10px;
  font-size: 28px;
  line-height: 1;
  font-weight: 900;
  color: #0f172a;
}

.emma-c6-kpi-hint {
  font-size: 14px;
  line-height: 1.45;
  color: #64748b;
}

/* ---------- Generic cards ---------- */

.yupy-card {
  border: 1px solid rgba(15, 23, 42, .08);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(15, 23, 42, .04);
  overflow: hidden;
}

.yupy-card-head {
  padding: 18px 20px 0;
}

.yupy-card-head .yupy-h3 {
  margin: 0 0 6px;
}

.yupy-card-head .yupy-muted {
  margin: 0;
  line-height: 1.45;
}

.yupy-card-body {
  padding: 18px 20px 20px;
}

/* ---------- Progress block ---------- */

.emma-c6-progress-card {
  margin: 0;
}

.emma-c6-progress-bars {
  display: grid;
  gap: 18px;
  margin-top: 8px;
}

.emma-c6-progress-row {
  display: grid;
  gap: 8px;
}

.emma-c6-progress-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;

  font-size: 14px;
  color: #334155;
}

.emma-c6-progress-top strong {
  color: #0f172a;
}

.emma-c6-progress-top span {
  font-weight: 800;
  color: #334155;
}

.emma-c6-progress-track {
  height: 14px;
  border-radius: 999px;
  background: #e5e7eb;
  border: 1px solid rgba(15, 23, 42, .06);
  overflow: hidden;
}

.emma-c6-progress-fill {
  height: 100%;
  min-width: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, #157fd6 0%, #63cbe1 100%);
}

.emma-c6-progress-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 22px;
}

.emma-c6-mini-kpi {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 42, .08);
  background: #f8fafc;
}

.emma-c6-mini-kpi span {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  font-weight: 800;
  color: #64748b;
}

.emma-c6-mini-kpi strong {
  display: block;
  font-size: 28px;
  line-height: 1.05;
  color: #020617;
}

/* ---------- Tables ---------- */

.emma-c6-mini-table th,
.emma-c6-mini-table td,
.yupy-table th,
.yupy-table td {
  padding: 14px 16px;
  vertical-align: top;
}

.yupy-table th {
  font-size: 13px;
  font-weight: 800;
}

.yupy-table td {
  line-height: 1.45;
}

/* ---------- Small top meta / shortcode pill ---------- */

.emma-c6-shortcode,
.emma-c6-pill,
.emma-c6-meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;

  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, .10);
  background: #fff;
}

/* ---------- Responsive ---------- */

@media (max-width: 1100px) {
  .emma-c6-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .emma-c6-progress-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .emma-c6-overview-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .emma-c6-hero {
    padding: 22px 18px;
  }

  .emma-c6-hero h2 {
    font-size: 24px;
  }

  .emma-c6-kpi-grid,
  .emma-c6-progress-kpis {
    grid-template-columns: 1fr;
  }

  .yupy-card-body,
  .yupy-card-head {
    padding-left: 16px;
    padding-right: 16px;
  }

  .emma-c6-nav,
  .emma-c6-topbar,
  .emma-c6-menu-bar,
  .emma-c6-header-nav {
    padding: 12px 14px;
    min-height: auto;
  }
}