/* =============================================================
   MS-PRO NEXT GENERATION — COMPONENTS
   Buttons, cards, badges, pills, tooltips, modals, pagination
   ============================================================= */

/* ══════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--btn-padding-y, var(--space-2-5)) var(--btn-padding-x, var(--space-5));
  font-family: var(--btn-font, var(--font-primary, 'Inter', sans-serif));
  font-size: var(--btn-font-size, var(--text-sm));
  font-weight: var(--fw-semibold);
  line-height: 1;
  border: 1.5px solid transparent;
  border-radius: var(--btn-radius, var(--radius-lg));
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
  user-select: none;
}
.btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.1);
  opacity: 0;
  transition: opacity var(--transition-fast);
}
.btn:hover::after { opacity: 1; }
.btn:active { transform: translateY(1px); }

/* Sizes */
.btn-xs { padding: var(--space-1) var(--space-3); font-size: var(--text-xs); border-radius: var(--radius-md); }
.btn-sm { padding: var(--space-2) var(--space-4); font-size: var(--text-sm); }
.btn-lg { padding: var(--space-4) var(--space-8); font-size: var(--text-lg); }
.btn-xl { padding: var(--space-5) var(--space-10); font-size: var(--text-xl); }

/* Variants */
.btn-primary {
  background: var(--btn-bg, var(--color-primary));
  color: var(--btn-text, #fff);
  border-color: var(--btn-border, var(--color-primary));
  box-shadow: var(--shadow-primary);
}
.btn-primary:hover {
  background: var(--btn-hover-bg, var(--color-primary-hover));
  border-color: var(--btn-hover-bg, var(--color-primary-hover));
  box-shadow: 0 6px 20px rgba(var(--color-primary-rgb), 0.4);
  color: var(--btn-hover-text, #fff);
}

.btn-secondary {
  background: var(--color-secondary);
  color: #fff;
  border-color: var(--color-secondary);
}
.btn-secondary:hover {
  background: var(--color-secondary-hover);
  border-color: var(--color-secondary-hover);
  color: #fff;
}

.btn-accent {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}
.btn-accent:hover { background: var(--color-accent-hover); color: #fff; }

.btn-outline {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-outline:hover {
  background: var(--color-primary);
  color: #fff;
}

.btn-ghost {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-border);
}
.btn-ghost:hover {
  background: var(--color-surface-2);
  border-color: var(--color-border);
  color: var(--color-heading);
}

.btn-danger {
  background: var(--color-error);
  color: #fff;
  border-color: var(--color-error);
}
.btn-danger:hover { background: #dc2626; color: #fff; }

.btn-live {
  background: var(--color-live);
  color: #fff;
  border-color: var(--color-live);
  animation: glow-pulse 2s infinite;
}

/* ══════════════════════════════════════
   POST CARDS
   ══════════════════════════════════════ */
.mspng-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  overflow: hidden;
  transition: box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-base);
  position: relative;
}
.mspng-card:hover {
  box-shadow: var(--card-shadow-hover);
  border-color: rgba(var(--color-primary-rgb), 0.2);
}
/* Note: transform/opacity on hover is injected by CSS Bridge based on img_hover setting */

/* Card Thumbnail */
.mspng-card__thumb {
  position: relative;
  overflow: hidden;
  background: var(--color-surface-2);
}
.mspng-card__thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,23,42,0.4) 0%, transparent 50%);
  opacity: 0;
  transition: opacity var(--transition-base);
}
.mspng-card:hover .mspng-card__thumb::after { opacity: 1; }

.mspng-card__img {
  width: 100%;
  aspect-ratio: var(--card-img-ratio, 16/9);
  object-fit: var(--card-img-fit, cover);
  border-radius: var(--card-img-radius, 0);
  transition: transform var(--transition-slow), opacity var(--transition-base);
  display: block;
}
/* Default zoom — overridden by CSS Bridge img_hover setting */
.mspng-card:hover .mspng-card__img { transform: scale(1.04); }

/* Card Body */
.mspng-card__body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}

/* Card Meta */
.mspng-card__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* Card Category */
.mspng-card__cat {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  background: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  transition: all var(--transition-fast);
}
.mspng-card__cat:hover {
  background: var(--color-primary);
  color: #fff;
}

/* Card Title */
.mspng-card__title {
  font-family: var(--font-display, 'Plus Jakarta Sans', system-ui, sans-serif);
  font-size: var(--card-title-size, var(--text-lg));
  font-weight: var(--card-title-weight, var(--fw-bold));
  line-height: var(--lh-snug);
  color: var(--color-heading);
  transition: color var(--transition-fast);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 0;
}
.mspng-card__title a { color: inherit; }
.mspng-card__title a:hover { color: var(--color-primary); }

/* Card Excerpt */
.mspng-card__excerpt {
  font-size: var(--card-excerpt-size, var(--text-sm));
  font-family: var(--font-primary, 'Inter', system-ui, sans-serif);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Card Footer */
.mspng-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
  margin-top: auto;
}

/* Card Author */
.mspng-card__author {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--color-text-muted);
}
.mspng-card__author img {
  width: 24px;
  height: 24px;
  border-radius: var(--radius-full);
  object-fit: cover;
}

/* Card Reading Time */
.mspng-card__read-time {
  font-size: var(--text-xs);
  color: var(--color-text-subtle);
  display: flex;
  align-items: center;
  gap: 3px;
}

/* ── Featured Card ── */
.card-featured {
  --card-radius: var(--radius-2xl);
  position: relative;
}
.card-featured .mspng-card__img { aspect-ratio: 16/9; }
.card-featured .mspng-card__body { padding: var(--space-6); }
.card-featured .mspng-card__title { font-size: var(--text-2xl); -webkit-line-clamp: 2; }

/* ── Card List Layout ── */
.card-list {
  display: flex;
  gap: var(--space-5);
  border-radius: var(--radius-xl);
}
.card-list .mspng-card__thumb { flex-shrink: 0; width: 140px; }
.card-list .mspng-card__img   { width: 140px; height: 100%; aspect-ratio: unset; }
.card-list .mspng-card__body  { padding: var(--space-4); }
.card-list .mspng-card__title { font-size: var(--text-base); -webkit-line-clamp: 2; }

/* ── Card Numbered (Popular/Trending) ── */
.card-numbered {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.card-numbered:last-child { border-bottom: none; }
.card-numbered__num {
  font-size: var(--text-3xl);
  font-weight: var(--fw-black);
  color: var(--color-border);
  line-height: 1;
  min-width: 32px;
  font-family: var(--font-display);
}
.card-numbered:hover .card-numbered__num { color: var(--color-primary); }
.card-numbered__content { flex: 1; min-width: 0; }
.card-numbered__title {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-heading);
  line-height: var(--lh-snug);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color var(--transition-fast);
}
.card-numbered:hover .card-numbered__title { color: var(--color-primary); }

/* ══════════════════════════════════════
   BADGES & PILLS
   ══════════════════════════════════════ */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 8px;
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  border-radius: var(--radius-full);
  white-space: nowrap;
  letter-spacing: var(--ls-wide);
}

.badge-primary   { background: var(--color-primary-light); color: var(--color-primary); }
.badge-secondary { background: var(--color-secondary-light); color: var(--color-secondary); }
.badge-accent    { background: var(--color-accent-light); color: var(--color-accent-hover); }
.badge-success   { background: var(--color-success-light); color: var(--color-success); }
.badge-error     { background: var(--color-error-light); color: var(--color-error); }
.badge-warning   { background: var(--color-warning-light); color: var(--color-warning); }

/* Live badge — pulsing */
.badge-live {
  background: var(--color-live);
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  animation: none;
  box-shadow: 0 0 0 0 var(--color-live-glow);
}
.badge-live::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: var(--radius-full);
  animation: pulse-live 1.4s ease-in-out infinite;
}

/* ══════════════════════════════════════
   CATEGORY LABEL (COLORED)
   ══════════════════════════════════════ */
.cat-label {
  display: inline-block;
  padding: 3px 10px;
  font-size: 10px;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  transition: all var(--transition-fast);
}
.cat-label:hover { filter: brightness(1.1); color: #fff; }

/* ══════════════════════════════════════
   PAGINATION
   ══════════════════════════════════════ */
.mspng-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-10);
}

.mspng-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-3);
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: all var(--transition-fast);
}
.mspng-pagination .page-numbers:hover,
.mspng-pagination .page-numbers.current {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
  box-shadow: var(--shadow-primary);
}
.mspng-pagination .page-numbers.dots { pointer-events: none; background: transparent; border-color: transparent; }
.mspng-pagination .prev, .mspng-pagination .next { padding: 0 var(--space-4); }

/* ══════════════════════════════════════
   TAGS
   ══════════════════════════════════════ */
.mspng-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}
.mspng-tags .tag {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--color-text-muted);
  transition: all var(--transition-fast);
}
.mspng-tags .tag:hover {
  background: var(--color-primary-light);
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* ══════════════════════════════════════
   SOCIAL SHARE STRIP
   ══════════════════════════════════════ */
.mspng-social-share {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.mspng-social-share__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1-5);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: #fff;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--transition-fast);
}
.mspng-social-share__btn:hover { filter: brightness(1.1); color: #fff; transform: translateY(-1px); }
.share-x         { background: #000; }
.share-facebook  { background: #1877f2; }
.share-whatsapp  { background: #25d366; }
.share-linkedin  { background: #0a66c2; }
.share-copy      { background: var(--color-surface-2); color: var(--color-text) !important; border: 1px solid var(--color-border); }
.share-copy:hover { background: var(--color-surface-3); }

/* ══════════════════════════════════════
   AUTHOR BOX
   ══════════════════════════════════════ */
.mspng-author-box {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
  padding: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
}
.mspng-author-box__avatar {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: var(--radius-full);
  overflow: hidden;
  border: 3px solid var(--color-primary-light);
}
.mspng-author-box__avatar img { width: 100%; height: 100%; object-fit: cover; }
.mspng-author-box__name { font-family: var(--font-display); font-size: var(--text-lg); font-weight: var(--fw-bold); color: var(--color-heading); margin-bottom: var(--space-1); }
.mspng-author-box__bio  { font-size: var(--text-sm); color: var(--color-text-muted); line-height: var(--lh-relaxed); }

/* ══════════════════════════════════════
   BREADCRUMBS
   ══════════════════════════════════════ */
.mspng-breadcrumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}
.mspng-breadcrumbs a { color: var(--color-text-muted); transition: color var(--transition-fast); }
.mspng-breadcrumbs a:hover { color: var(--color-primary); }
.mspng-breadcrumbs .sep { color: var(--color-text-subtle); }
.mspng-breadcrumbs .current { color: var(--color-text); font-weight: var(--fw-medium); }

/* ══════════════════════════════════════
   AFFILIATE / REVIEW CARDS
   ══════════════════════════════════════ */
.mspng-affiliate-box {
  border: 2px solid var(--color-accent-light);
  border-radius: var(--card-radius);
  overflow: hidden;
  background: var(--color-surface);
  box-shadow: var(--shadow-md);
}
.mspng-affiliate-box__header {
  background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
  color: #fff;
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-widest);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.mspng-affiliate-box__body { padding: var(--space-5); }

/* ══════════════════════════════════════
   AD BLOCKS
   ══════════════════════════════════════ */
.mspng-ad-block {
  text-align: center;
  padding: var(--space-2) 0;
}
.mspng-ad-block__label {
  font-size: 10px;
  color: var(--color-text-subtle);
  text-transform: uppercase;
  letter-spacing: var(--ls-widest);
  margin-bottom: var(--space-2);
  display: block;
}

/* ══════════════════════════════════════
   NEWSLETTER BOX
   ══════════════════════════════════════ */
.mspng-newsletter {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
  border-radius: var(--radius-2xl);
  padding: var(--space-10) var(--space-8);
  text-align: center;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.mspng-newsletter::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 400px;
  height: 400px;
  background: rgba(255,255,255,0.05);
  border-radius: var(--radius-full);
  pointer-events: none;
}
.mspng-newsletter__title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--fw-extrabold);
  margin-bottom: var(--space-3);
  color: #fff;
}
.mspng-newsletter__desc { font-size: var(--text-base); opacity: 0.9; margin-bottom: var(--space-6); }
.mspng-newsletter__form {
  display: flex;
  gap: var(--space-3);
  max-width: 440px;
  margin: 0 auto;
}
.mspng-newsletter__input {
  flex: 1;
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-full);
  border: 2px solid rgba(255,255,255,0.3);
  background: rgba(255,255,255,0.15);
  color: #fff;
  font-size: var(--text-base);
  outline: none;
}
.mspng-newsletter__input::placeholder { color: rgba(255,255,255,0.6); }
.mspng-newsletter__input:focus { border-color: rgba(255,255,255,0.7); background: rgba(255,255,255,0.2); }
.mspng-newsletter__btn {
  background: #fff;
  color: var(--color-primary);
  font-weight: var(--fw-bold);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full);
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--transition-fast);
}
.mspng-newsletter__btn:hover { background: var(--color-accent); color: #fff; }

@media (max-width: 480px) {
  .mspng-newsletter__form { flex-direction: column; }
  .mspng-newsletter__btn { width: 100%; }
}
