/* ===================== UTILITY CLASSES ===================== */
.nch-mb-0 { margin-bottom: 0 !important; }
.nch-mb-2 { margin-bottom: var(--nett-space-2) !important; }
.nch-mb-4 { margin-bottom: var(--nett-space-4) !important; }
.nch-mb-6 { margin-bottom: var(--nett-space-6) !important; }
.nch-text-center { text-align: center !important; }
.nch-fw-bold { font-weight: var(--nett-font-bold) !important; }
.nch-fw-extrabold { font-weight: var(--nett-font-extrabold) !important; }
.nch-uppercase { text-transform: uppercase !important; }
.nch-ls-wide { letter-spacing: var(--nett-tracking-wider) !important; }
.nch-shadow { box-shadow: var(--nett-shadow-md) !important; }
.nch-radius-lg { border-radius: var(--nett-radius-lg) !important; }
.nch-radius-xl { border-radius: var(--nett-radius-xl) !important; }
.nch-radius-full { border-radius: var(--nett-radius-full) !important; }
/* ===================== EXTRA ANIMATIONS ===================== */
@keyframes nch-fade-in {
  from { opacity: 0; transform: translateY(40px); }
  to { opacity: 1; transform: none; }
}
.nc-card[data-anim="fade-in"] { animation: nch-fade-in 0.8s var(--nett-ease) both !important; }
@keyframes nch-slide-in {
  from { opacity: 0; transform: translateX(-40px); }
  to { opacity: 1; transform: none; }
}
.nc-card[data-anim="slide-in"] { animation: nch-slide-in 0.8s var(--nett-ease) both !important; }
@keyframes nch-zoom-in {
  from { opacity: 0; transform: scale(0.95); }
  to { opacity: 1; transform: scale(1); }
}
.nc-card[data-anim="zoom-in"] { animation: nch-zoom-in 0.7s var(--nett-ease) both !important; }
/* ===================== END OF UPGRADE (300+ lines, all markup covered, !important everywhere) ===================== */
/*
 * NETT CATEGORY HIGHLIGHTS WIDGET CSS
 * Menggunakan variabel dari _master-variables/_master-variables.css
 * Semua style menggunakan !important agar prioritas tinggi
 * Minimal 300 baris, termasuk animasi dan responsive
 */

:root {
  /* Import master variables (pastikan file _master-variables.css sudah di-load di theme/plugin) */
}

/* ===================== SECTION WRAPPER ===================== */
.nc-section,
.nc-section[class*="nc-section-"] {
  background: var(--nett-bg-primary) !important;
  color: var(--nett-text-primary) !important;
  font-family: var(--nett-font-body) !important;
  padding: var(--nett-section-padding-y) var(--nett-section-padding-x) !important;
  position: relative !important;
  overflow: hidden !important;
  z-index: var(--nett-z-0) !important;
}

/* ===================== HEADER ===================== */
.nc-header {
  text-align: center !important;
  margin-bottom: var(--nett-space-16) !important;
  opacity: 0 !important;
  transform: translateY(30px) !important;
  transition: all var(--nett-duration-700) var(--nett-ease) !important;
}
.nc-header.active { opacity: 1 !important; transform: translateY(0) !important; }

.nc-subtitle {
  font-family: var(--nett-font-heading) !important;
  font-size: var(--nett-text-sm) !important;
  font-weight: var(--nett-font-bold) !important;
  color: var(--nett-primary) !important;
  text-transform: uppercase !important;
  letter-spacing: var(--nett-tracking-wider) !important;
  margin-bottom: var(--nett-space-2) !important;
}

.nc-title,
.nc-header h1,
.nc-header h2,
.nc-header h3 {
  font-family: var(--nett-font-heading) !important;
  font-size: var(--nett-h2-size) !important;
  font-weight: var(--nett-font-extrabold) !important;
  color: var(--nett-text-primary) !important;
  margin-bottom: var(--nett-space-4) !important;
  line-height: var(--nett-leading-tight) !important;
  letter-spacing: var(--nett-tracking-tight) !important;
}

.nc-header-desc {
  font-size: var(--nett-text-lg) !important;
  color: var(--nett-text-secondary) !important;
  margin-top: var(--nett-space-2) !important;
  margin-bottom: 0 !important;
  line-height: var(--nett-leading-normal) !important;
}

/* ===================== GRID ===================== */
.nc-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--nett-gap-lg) !important;
  margin-bottom: 0 !important;
}
@media (max-width: 1024px) {
  .nc-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px) {
  .nc-grid { grid-template-columns: 1fr !important; }
}

/* ===================== CARD ===================== */
.nc-card {
  background: var(--nett-card-bg) !important;
  border-radius: var(--nett-card-radius) !important;
  box-shadow: var(--nett-card-shadow) !important;
  padding: var(--nett-card-padding) !important;
  position: relative !important;
  z-index: var(--nett-z-10) !important;
  border: var(--nett-border) solid var(--nett-card-border) !important;
  transition: box-shadow var(--nett-duration-300) var(--nett-ease), border-color var(--nett-duration-300) var(--nett-ease) !important;
  cursor: pointer !important;
  overflow: hidden !important;
  opacity: 0 !important;
  transform: translateY(30px) !important;
}
.nc-card.active { opacity: 1 !important; transform: translateY(0) !important; }
.nc-card:hover {
  box-shadow: var(--nett-card-shadow-hover) !important;
  border-color: var(--nett-primary) !important;
}

.nc-card-img {
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  border-radius: var(--nett-radius-xl) var(--nett-radius-xl) 0 0 !important;
  filter: brightness(100%) contrast(100%) grayscale(0%) blur(0px) !important;
  transition: filter var(--nett-duration-300) var(--nett-ease), transform var(--nett-duration-700) var(--nett-ease) !important;
}
.nc-card:hover .nc-card-img {
  filter: brightness(110%) contrast(110%) grayscale(0%) blur(0px) !important;
  transform: scale(1.05) !important;
}

.nc-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: var(--nett-gradient-dark) !important;
  opacity: 0.7 !important;
  pointer-events: none !important;
  z-index: var(--nett-z-0) !important;
  transition: opacity var(--nett-duration-300) var(--nett-ease) !important;
}
.nc-card:hover .nc-overlay { opacity: 0.9 !important; }

.nc-content {
  position: relative !important;
  z-index: var(--nett-z-10) !important;
  padding: var(--nett-space-6) !important;
  background: var(--nett-bg-overlay-light) !important;
  border-radius: 0 0 var(--nett-radius-xl) var(--nett-radius-xl) !important;
}

/* ===================== ICON ===================== */
.nc-icon-box {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 48px !important;
  height: 48px !important;
  background: var(--nett-gradient-primary) !important;
  color: var(--nett-white) !important;
  border-radius: var(--nett-radius-full) !important;
  box-shadow: var(--nett-shadow-lg) !important;
  margin: 0 auto var(--nett-space-2) auto !important;
  font-size: 24px !important;
  border: var(--nett-border) solid var(--nett-primary) !important;
  transition: background var(--nett-duration-300) var(--nett-ease), color var(--nett-duration-300) var(--nett-ease) !important;
}
.nc-icon-box.nc-icon-circle { border-radius: var(--nett-radius-full) !important; }
.nc-icon-box.nc-icon-rounded { border-radius: var(--nett-radius-xl) !important; }

.nc-icon-box svg,
.nc-icon-box i {
  width: 1em !important;
  height: 1em !important;
  display: block !important;
}

/* ===================== CARD TITLE ===================== */
.nc-card-title {
  font-family: var(--nett-font-heading) !important;
  font-size: var(--nett-h4-size) !important;
  font-weight: var(--nett-font-bold) !important;
  color: var(--nett-text-primary) !important;
  margin-bottom: var(--nett-space-2) !important;
  line-height: var(--nett-leading-tight) !important;
  letter-spacing: var(--nett-tracking-tight) !important;
  text-align: center !important;
}

/* ===================== CARD DESC ===================== */
.nc-card-desc {
  font-size: var(--nett-text-base) !important;
  color: var(--nett-text-secondary) !important;
  margin-bottom: var(--nett-space-4) !important;
  line-height: var(--nett-leading-normal) !important;
  text-align: center !important;
  opacity: 0.85 !important;
  transition: opacity var(--nett-duration-300) var(--nett-ease), transform var(--nett-duration-300) var(--nett-ease) !important;
}
.nc-card:hover .nc-card-desc {
  opacity: 1 !important;
  transform: translateY(-8px) !important;
}

/* ===================== CARD BUTTON ===================== */
.nc-card-link {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--nett-space-2) !important;
  font-size: var(--nett-btn-font-size) !important;
  font-weight: var(--nett-btn-font-weight) !important;
  color: var(--nett-btn-primary-text) !important;
  background: var(--nett-btn-primary-bg) !important;
  border-radius: var(--nett-btn-radius) !important;
  padding: var(--nett-btn-padding-y) var(--nett-btn-padding-x) !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  box-shadow: var(--nett-shadow-sm) !important;
  border: none !important;
  transition: background var(--nett-duration-300) var(--nett-ease), color var(--nett-duration-300) var(--nett-ease), gap var(--nett-duration-300) var(--nett-ease) !important;
  margin-top: var(--nett-space-2) !important;
}
.nc-card-link:hover {
  background: var(--nett-btn-primary-hover-bg) !important;
  color: var(--nett-white) !important;
  gap: var(--nett-space-4) !important;
}

.nc-card-link i,
.nc-card-link svg {
  width: 1em !important;
  height: 1em !important;
  font-size: 1em !important;
}

/* ===================== ANIMATIONS ===================== */
@keyframes nc-reveal {
  0% { opacity: 0; transform: translateY(30px); }
  100% { opacity: 1; transform: translateY(0); }
}
.nc-card.reveal,
.nc-header.reveal {
  animation: nc-reveal 0.8s var(--nett-ease) forwards !important;
}

@keyframes nc-tilt {
  0% { transform: rotate(0deg) scale(1); }
  50% { transform: rotate(2deg) scale(1.02); }
  100% { transform: rotate(-2deg) scale(1.01); }
}
.nc-card.random-hover:hover {
  animation: nc-tilt 0.7s var(--nett-ease) alternate infinite !important;
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 1024px) {
  .nc-card { padding: var(--nett-space-4) !important; }
  .nc-title { font-size: var(--nett-h3-size) !important; }
}
@media (max-width: 600px) {
  .nc-card { padding: var(--nett-space-2) !important; }
  .nc-title { font-size: var(--nett-h4-size) !important; }
}

@media (max-width: 480px) {
  .nc-section { padding: var(--nett-space-4) !important; }
  .nc-header { margin-bottom: var(--nett-space-8) !important; }
  .nc-subtitle { font-size: 11px !important; }
  .nc-title { font-size: 20px !important; }
  .nc-card-title { font-size: 16px !important; }
  .nc-card-desc { font-size: 13px !important; margin-bottom: var(--nett-space-2) !important; }
  .nc-card-img { height: 140px !important; }
  .nc-icon-box { width: 40px !important; height: 40px !important; font-size: 18px !important; }
  .nc-card-link { padding: var(--nett-space-2) var(--nett-space-4) !important; font-size: 12px !important; }
  .nc-content { padding: var(--nett-space-4) !important; }
}

/* ===================== UTILITY ===================== */
.nc-hide { display: none !important; }
.nc-center { text-align: center !important; }
.nc-mb-0 { margin-bottom: 0 !important; }
.nc-mb-4 { margin-bottom: var(--nett-space-4) !important; }
.nc-mb-8 { margin-bottom: var(--nett-space-8) !important; }

/* ===================== END OF FILE ===================== */
