/* Chi bo - Dang vien home panel. */

.panel__title--party {
  gap: var(--space-2);
}

.panel__title--party [data-icon] {
  color: var(--color-party-cyan);
}

.party-panel__title-text {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.party-panel__flag {
  position: relative;
  display: block;
  flex: 0 0 auto;
  width: 1.55rem;
  height: 1.05rem;
  margin-left: var(--space-1);
  overflow: hidden;
  background:
    radial-gradient(circle at 32% 38%, var(--color-party-warning) 0 0.1rem, transparent 0.12rem),
    linear-gradient(135deg, var(--color-party-risk), color-mix(in srgb, var(--color-party-risk) 72%, var(--color-party-bg-deep)));
  border: 1px solid color-mix(in srgb, var(--color-party-warning) 42%, transparent);
  box-shadow:
    inset 0 0 0.38rem color-mix(in srgb, var(--color-party-warning) 12%, transparent),
    0 0 0.45rem color-mix(in srgb, var(--color-party-risk) 28%, transparent);
  filter: drop-shadow(0 0 0.45rem color-mix(in srgb, var(--color-party-risk) 44%, transparent));
}

.party-panel__flag::after {
  position: absolute;
  top: 0;
  right: -0.16rem;
  width: 0.42rem;
  height: 100%;
  background: color-mix(in srgb, var(--color-party-bg-deep) 48%, transparent);
  content: "";
  transform: skewX(-16deg);
}

.party-panel__flag span {
  display: none;
}

.party-panel__period {
  flex: 0 0 auto;
  margin-left: auto;
  padding: 0 var(--space-2);
  color: var(--color-header-text-cyan);
  font-size: var(--text-2xs);
  font-weight: 900;
  line-height: 1.45;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--alpha-blue-21176139-64), var(--alpha-deep-011234-18));
  border: 1px solid var(--alpha-blue-42165255-16);
}

.party-panel__detail-button {
  flex: 0 0 auto;
  padding: 0 var(--space-2);
  color: var(--color-text);
  font-family: var(--font-base);
  font-size: var(--text-2xs);
  font-weight: 900;
  line-height: 1.45;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--alpha-cyan-22200255-10), var(--alpha-blue-21176139-64));
  border: 1px solid var(--alpha-cyan-22200255-42);
  box-shadow: 0 0 0.65rem var(--alpha-cyan-19187255-18);
  cursor: pointer;
}

.party-panel__detail-button:hover {
  color: var(--color-white);
  border-color: var(--alpha-cyan-22200255-80);
}

.party-kpi {
  height: calc(100% - 2.25rem);
  min-height: 0;
  padding: 0.35rem var(--space-2) var(--space-2);
  overflow: hidden;
}

.party-visual {
  position: relative;
  display: grid;
  grid-template-rows: minmax(0, 1fr) 2.15rem;
  gap: 0.35rem;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--color-party-bg-deep) 94%, var(--color-black)), var(--color-party-bg-mid), color-mix(in srgb, var(--color-party-bg-deep) 96%, var(--color-black))),
    radial-gradient(circle at 14% 20%, color-mix(in srgb, var(--color-party-success) 13%, transparent), transparent 34%),
    radial-gradient(circle at 72% 55%, color-mix(in srgb, var(--color-party-cyan) 9%, transparent), transparent 42%);
  border: 1px solid color-mix(in srgb, var(--color-party-cyan) 16%, transparent);
  box-shadow:
    inset 0 0 1.35rem color-mix(in srgb, var(--color-party-cyan) 6%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--color-white) 4%, transparent);
}

.party-visual::before {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent, var(--alpha-cyan-19187255-055), transparent),
    repeating-linear-gradient(90deg, transparent 0 7.4rem, var(--alpha-cyan-19187255-045) 7.4rem 7.45rem);
  content: "";
}

.party-command__main,
.party-command__facts {
  position: relative;
  z-index: 1;
  min-width: 0;
  min-height: 0;
}

.party-command__main {
  display: grid;
  grid-template-columns: minmax(7.8rem, 1.08fr) minmax(7.8rem, 1.08fr) minmax(10.2rem, 1.45fr) minmax(9.2rem, 1.18fr) minmax(8.55rem, 1.08fr);
  gap: 0.35rem;
  padding: 0.35rem 0.35rem 0;
}

.party-command__facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.35rem;
  padding: 0 0.35rem 0.35rem;
}

/* Nền tile dùng chung từ .stat-tile (components.css). Ở đây chỉ cầu nối tone:
   map --party-tone của khối Đảng sang biến --tone của primitive dùng chung. */
.party-hero,
.party-chart-card,
.party-intel,
.party-fact {
  --tone: var(--party-tone, var(--color-party-cyan));
}

.party-hero--success,
.party-fact--success,
.party-intel-chip--success {
  --party-tone: var(--color-party-success);
}

.party-hero--info,
.party-fact--info,
.party-intel-chip--info {
  --party-tone: var(--color-party-cyan);
}

.party-fact--warning,
.party-intel-chip--warning {
  --party-tone: var(--color-party-warning);
}

.party-fact--danger,
.party-intel-chip--danger {
  --party-tone: var(--color-party-risk);
}

.party-hero {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto auto;
  gap: 0.28rem;
  padding: 0.5rem 0.55rem;
}

.party-hero__top {
  display: grid;
  grid-template-columns: 1.7rem minmax(0, 1fr);
  align-items: center;
  gap: 0.35rem;
  min-width: 0;
}

.party-hero__icon {
  display: grid;
  place-items: center;
  width: 1.7rem;
  height: 1.7rem;
  color: var(--party-tone);
  background: color-mix(in srgb, var(--party-tone) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--party-tone) 22%, transparent);
  filter: drop-shadow(0 0 0.45rem color-mix(in srgb, var(--party-tone) 28%, transparent));
}

/* Số hero (1.770/100) & nhãn dùng .stat-value--hero / .stat-label (components.css).
   Cỡ chữ theo breakpoint vẫn được override bên dưới qua .party-hero__top strong. */
.party-hero__delta {
  display: grid;
  gap: 0.15rem;
}

.party-hero__delta b {
  color: var(--party-tone);
  font-size: var(--text-md);
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.party-hero__delta span {
  min-width: 0;
  overflow: hidden;
  color: var(--color-text);
  font-size: var(--text-2xs);
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.party-chart-card {
  --party-tone: var(--color-party-cyan);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 0.15rem;
  padding: 0.45rem 0.45rem 0.2rem;
}

.party-chart-card--trend {
  --party-tone: var(--color-party-success);
}

.party-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-1);
  min-width: 0;
}

.party-card-head span,
.party-card-head strong {
  min-width: 0;
  overflow: hidden;
  font-size: var(--text-2xs);
  font-weight: 900;
  line-height: 1;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.party-card-head span {
  color: var(--color-text);
}

.party-card-head strong {
  flex: 0 0 auto;
  color: var(--party-tone);
}

.party-echart {
  width: 100%;
  height: 100%;
  min-height: 0;
}

.party-intel {
  --party-tone: var(--color-party-success);
  display: grid;
  align-content: center;
  grid-template-rows: auto auto;
  gap: 0.3rem;
  padding: 0.42rem;
}

.party-intel__status {
  display: grid;
  align-items: center;
  min-width: 0;
  min-height: 2.7rem;
  padding-left: 0.52rem;
  border-left: 0.18rem solid color-mix(in srgb, var(--color-party-success) 68%, transparent);
}

.party-intel__status div {
  display: grid;
  gap: 0.14rem;
  min-width: 0;
}

.party-intel__status strong {
  color: var(--color-party-success);
  font-size: var(--text-xl);
  font-weight: 900;
  line-height: 0.96;
  text-transform: uppercase;
  text-shadow: 0 0 0.75rem color-mix(in srgb, var(--color-party-success) 25%, transparent);
}

.party-intel__status span {
  min-width: 0;
  overflow: hidden;
  color: var(--color-text);
  font-size: var(--text-2xs);
  font-weight: 900;
  line-height: 1;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.party-intel__chips {
  display: grid;
  gap: 0.18rem;
  min-height: 0;
}

.party-intel-chip {
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr);
  align-items: center;
  gap: 0.22rem;
  min-width: 0;
  min-height: 1.02rem;
  padding: 0.15rem 0.24rem;
  color: var(--color-text);
  background: color-mix(in srgb, var(--party-tone) 8%, transparent);
  border-left: 0.12rem solid color-mix(in srgb, var(--party-tone) 68%, transparent);
}

.party-intel-chip span {
  display: grid;
  place-items: center;
  color: var(--party-tone);
}

.party-intel-chip i {
  min-width: 0;
  overflow: hidden;
  font-size: var(--text-2xs);
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.party-intel-chip i {
  color: var(--color-text);
}

.party-fact {
  display: grid;
  grid-template-columns: 1.25rem auto minmax(0, 1fr);
  align-items: center;
  gap: 0.28rem;
  padding: 0.26rem 0.45rem;
}

.party-fact__icon {
  display: grid;
  place-items: center;
  color: var(--party-tone);
  filter: drop-shadow(0 0 0.35rem color-mix(in srgb, var(--party-tone) 30%, transparent));
}

.party-fact strong {
  color: var(--party-tone);
  font-size: var(--text-xl);
  font-weight: 900;
  line-height: 1;
}

.party-fact span:last-child {
  min-width: 0;
  overflow: hidden;
  color: var(--color-text);
  font-size: var(--text-2xs);
  font-weight: 900;
  line-height: 1;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}


@media (max-width: 1180px) {
  .party-command__main {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto auto auto;
  }

  .party-chart-card,
  .party-intel {
    min-height: 8rem;
  }

  .party-chart-card--trend,
  .party-chart-card--movement {
    grid-column: auto;
  }

  .party-command__facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
