/* =========================================================
   GLOBAL / ROOT
   ========================================================= */
:root {
  --bg: radial-gradient(circle at top, #0f172a 0%, #0b1120 42%, #060816 80%);
  --bg-solid: #0b1120;
  --surface: rgba(12, 15, 25, 0.45);
  --card: #111827;
  --card-soft: rgba(17,24,39,.3);
  --border: rgba(255,255,255,.03);
  --text: #fff;
  --muted: rgba(226,232,255,.6);
  --purple: #8b5cf6;
  --purple2: #6366f1;
  --purple-soft: rgba(139,92,246,.12);
  --purple-border: rgba(139,92,246,.35);
  --danger: #e55353;
  --radius-lg: 1.1rem;
  --radius: .85rem;
  --shadow: 0 20px 60px rgba(0,0,0,.25);
}

body.lp-body {
  background: var(--bg);
  min-height: 100vh;
  color: var(--text);
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* fix bootstrap container di dark bg */
.container,
.container-fluid {
  max-width: 1200px;
}

/* =========================================================
   TOPBAR
   ========================================================= */
.lp-topbar {
  background: rgba(6, 8, 16, .78);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.02);
  position: sticky;
  top: 0;
  z-index: 999;
  min-height: 58px;
  display: flex;
  align-items: center;
}

.lp-brand-logo {
  height: 40px;
  object-fit: contain;
}

.lp-brand-text {
  font-weight: 700;
  font-size: 1.1rem;
  color: #fff;
}
.lp-brand-text span {
  color: var(--purple);
}

.lp-search-wrap {
  position: relative;
  flex: 0 0 330px;
  max-width: 360px;
}
.lp-search-input {
  width: 100%;
  height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.02);
  background: rgba(255,255,255,.02);
  color: #fff;
  padding: 0 2.8rem 0 .9rem;
  font-size: .8rem;
}
.lp-search-input::placeholder {
  color: rgba(255,255,255,.35);
}
.lp-search-btn {
  position: absolute;
  right: 3px;
  top: 3px;
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(140deg, var(--purple) 0%, var(--purple2) 100%);
  display: grid;
  place-items: center;
  color: #fff;
  cursor: pointer;
}

.lp-main-nav .lp-nav-link {
  color: rgba(255,255,255,.6);
  font-size: .78rem;
  text-decoration: none;
  padding: .35rem .65rem;
  border-radius: .5rem;
  transition: .15s ease;
}
.lp-main-nav .lp-nav-link:hover,
.lp-main-nav .lp-nav-link.active {
  color: #fff;
  background: rgba(139,92,246,.14);
  border: 1px solid rgba(139,92,246,.25);
}

.lp-btn-primary {
  background: linear-gradient(140deg, var(--purple) 0%, var(--purple2) 100%);
  border: none;
  color: #fff;
  border-radius: .45rem;
  font-size: .75rem;
}
.lp-btn-outline {
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  background: transparent;
  border-radius: .45rem;
  font-size: .75rem;
}

.lp-mobile-toggle {
  background: rgba(12,16,25,.35);
  border: 1px solid rgba(255,255,255,.03);
  border-radius: .4rem;
  width: 34px;
  height: 34px;
  display: none;
  align-items: center;
  justify-content: center;
  color: #fff;
}

.lp-mobile-panel {
  display: none;
  background: #0f172a;
  border-top: 1px solid rgba(255,255,255,.02);
  padding: .75rem 1rem 1rem 1rem;
}
.lp-mobile-panel.show { display: block; }
.lp-nav-link-mb {
  display: block;
  color: #fff;
  text-decoration: none;
  padding: .3rem 0;
  font-size: .8rem;
}

@media (max-width: 991px) {
  .lp-search-wrap.d-none.d-md-flex { display: none !important; }
  .lp-mobile-toggle { display: inline-flex; margin-left: auto; }
  .lp-main-nav { display: none !important; }
  .lp-topbar { min-height: auto; }
}

/* =========================================================
   HERO
   ========================================================= */
.lp-hero {
  margin-top: 1.2rem;
}
.lp-hero-head {
  max-width: 650px;
  margin: 0 auto 1rem auto;
  text-align: center;
}
.lp-hero-title {
  font-weight: 700;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
}
.lp-hero-sub {
  color: var(--muted);
  font-size: .8rem;
  margin-top: .25rem;
}

/* carousel tengah */
.lp-carousel-shell {
  width: 100%;
  margin-top: 1rem;
  position: relative;
  height: 360px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.lp-carousel {
  position: relative;
  width: min(1180px, 100%);
  height: 100%;
}
.lp-carousel__item {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 63%;
  height: 82%;
  transform: translate(-50%, -50%) scale(.65);
  border-radius: 1.05rem;
  overflow: hidden;
  opacity: 0;
  filter: brightness(.3);
  transition: transform .35s ease, opacity .35s ease, filter .35s ease;
  background: radial-gradient(circle at top, rgba(139,92,246,.2), rgba(5,6,10,0));
  box-shadow: var(--shadow);
}
.lp-carousel__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lp-carousel__item.is-active {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  filter: brightness(1);
  z-index: 3;
}
.lp-carousel__item.is-prev {
  opacity: 1;
  transform: translate(-115%, -50%) scale(.7);
  z-index: 2;
}
.lp-carousel__item.is-next {
  opacity: 1;
  transform: translate(15%, -50%) scale(.7);
  z-index: 2;
}
.lp-carousel__placeholder {
  display: grid;
  place-items: center;
  height: 100%;
  color: rgba(255,255,255,.7);
  text-align: center;
  padding: 1rem;
}

.lp-carousel__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  border-radius: .6rem;
  border: 0;
  background: rgba(3,6,10,.55);
  color: #fff;
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 10;
}
.lp-carousel__nav--prev { left: max(2.5rem, 3%); }
.lp-carousel__nav--next { right: max(2.5rem, 3%); }

.lp-carousel__dots {
  position: absolute;
  bottom: 1.2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: .4rem;
}
.lp-carousel__dots button {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,.15);
}
.lp-carousel__dots button.active {
  background: var(--purple);
  width: 24px;
}

/* =========================================================
   FLASH SALE
   ========================================================= */
.lp-flash {
  margin-top: 1.35rem;
  background: rgba(5,7,12,.45);
  padding: 1rem 0 1rem 0;
}
.lp-flash-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-inline: 1.5rem;
  margin-bottom: .45rem;
}
.lp-flash-icon {
  width: 30px;
  height: 30px;
  background: rgba(139,92,246,.25);
  border-radius: .6rem;
  display: grid;
  place-items: center;
  color: #fff;
}
.lp-flash-title {
  font-weight: 700;
  font-size: 1rem;
}
.lp-flash-timer {
  background: var(--danger);
  border-radius: .4rem;
  padding: .1rem .6rem .2rem .6rem;
  font-size: .7rem;
  font-weight: 600;
  margin-left: .5rem;
}

.lp-flash-controls {
  display: flex;
  gap: .35rem;
}
.lp-flash-nav {
  width: 30px;
  height: 30px;
  background: rgba(11,15,25,.4);
  border: 1px solid rgba(255,255,255,.02);
  border-radius: .5rem;
  color: #fff;
  display: grid;
  place-items: center;
}

.lp-flash-wrapper {
  overflow: hidden;
  padding-inline: 1.5rem;
}
.lp-flash-track {
  display: flex;
  gap: .75rem;
  transition: transform .35s ease;
}
.lp-flash-card {
  background: rgba(9,11,19,.55);
  border: 1px solid rgba(255,255,255,.02);
  border-radius: .95rem;
  min-width: 270px;
  max-width: 270px;
  position: relative;
  overflow: hidden;
}
.lp-flash-img {
  height: 110px;
  background: rgba(15,23,42,.25);
  position: relative;
}
.lp-flash-img img { width: 100%; height: 100%; object-fit: cover; }
.lp-flash-stock {
  position: absolute;
  top: 6px;
  right: 6px;
  background: rgba(232, 73, 110, .85);
  border-radius: 999px;
  padding: .12rem .7rem .25rem .7rem;
  font-size: .6rem;
  font-weight: 600;
}
.lp-flash-body {
  padding: .5rem .6rem .4rem .6rem;
}
.lp-flash-name { font-size: .72rem; }
.lp-flash-old {
  font-size: .6rem;
  color: rgba(255,116,116,.85);
  text-decoration: line-through;
}
.lp-flash-price {
  background: linear-gradient(135deg, #8b5cf6 0%, #6366f1 100%);
  position: absolute;
  right: 0;
  bottom: 0;
  padding: .25rem .6rem .4rem .6rem;
  border-top-left-radius: .6rem;
  font-weight: 600;
  font-size: .75rem;
}

.lp-flash-dots {
  display: flex;
  justify-content: center;
  gap: .35rem;
  padding-top: .45rem;
}
.lp-flash-dots button {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  border: none;
  background: rgba(255,255,255,.15);
}
.lp-flash-dots button.active {
  background: var(--purple);
  width: 22px;
}

/* =========================================================
   MENU / PRODUK
   ========================================================= */
.lp-menu {
  margin-top: 1.4rem;
}
.lp-menu-tabs {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  margin-bottom: .8rem;
}
.lp-menu-tabs button {
  background: rgba(12,16,25,.35);
  border: 1px solid rgba(255,255,255,.03);
  border-radius: .65rem;
  color: #fff;
  font-size: .73rem;
  padding: .38rem .85rem .45rem .85rem;
  display: flex;
  align-items: center;
  gap: .3rem;
  cursor: pointer;
}
.lp-menu-tabs button.active {
  background: rgba(139,92,246,.16);
  border-color: rgba(139,92,246,.45);
}
.lp-menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: .65rem;
}
.lp-menu-card {
  background: rgba(11,15,25,.45);
  border: 1px solid rgba(255,255,255,.01);
  border-radius: .9rem;
  overflow: hidden;
  min-height: 120px;
}
.lp-menu-thumb {
  height: 62px;
  background: rgba(15,23,42,.35);
}
.lp-menu-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lp-menu-thumb-placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: rgba(255,255,255,.35);
  font-size: .7rem;
}
.lp-menu-body {
  padding: .4rem .55rem .6rem .55rem;
}
.lp-menu-cat {
  font-size: .6rem;
  color: rgba(226,232,255,.4);
  margin-bottom: .2rem;
}
.lp-menu-title {
  font-size: .75rem;
  line-height: 1.25;
}

/* =========================================================
   POPULER
   ========================================================= */
.lp-popular { margin-top: 1.4rem; }
.lp-section-title { font-size: 1.05rem; font-weight: 700; }
.lp-popular-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px,1fr));
  gap: .7rem;
}
.lp-pop-card {
  background: rgba(12,16,25,.4);
  border: 1px solid rgba(255,255,255,.01);
  border-radius: 1rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.lp-pop-img {
  height: 140px;
  background: rgba(15,23,42,.25);
}
.lp-pop-img img { width: 100%; height: 100%; object-fit: cover; }
.lp-pop-placeholder {
  width: 100%;
  height: 100%;
  background: radial-gradient(circle at top, rgba(139,92,246,.35), rgba(15,23,42,0));
}
.lp-pop-body {
  padding: .5rem .6rem .7rem .6rem;
}
.lp-pop-body h3 {
  font-size: .78rem;
  margin-bottom: .15rem;
}
.lp-pop-body p {
  font-size: .63rem;
  color: rgba(226,232,255,.4);
}
.lp-btn-primary-outline {
  background: transparent;
  border: 1px solid rgba(139,92,246,.6);
  color: #fff;
  border-radius: .6rem;
  font-size: .72rem;
  padding: .35rem .8rem;
}

/* =========================================================
   ARTIKEL
   ========================================================= */
.lp-articles { margin-top: 1.4rem; }
.lp-article-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: .75rem;
}
.lp-article-card {
  background: rgba(12,16,25,.4);
  border: 1px solid rgba(255,255,255,.01);
  border-radius: 1rem;
  overflow: hidden;
}
.lp-article-card img,
.lp-article-placeholder {
  width: 100%;
  height: 135px;
  object-fit: cover;
  background: rgba(15,23,42,.35);
}
.lp-article-content {
  padding: .6rem .7rem .7rem .7rem;
}
.lp-article-tags {
  display: flex;
  gap: .4rem;
  margin-bottom: .45rem;
}
.lp-article-tags span {
  background: rgba(139,92,246,.15);
  border: 1px solid rgba(139,92,246,.35);
  border-radius: .6rem;
  font-size: .6rem;
  padding: .11rem .5rem .18rem .5rem;
}
.lp-article-content h3 {
  font-size: .8rem;
  margin-bottom: .35rem;
}
.lp-article-date {
  font-size: .6rem;
  color: rgba(236,242,255,.25);
}

/* =========================================================
   FOOTER
   ========================================================= */
.lp-footer-main {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}
.lp-footer-card {
  background: rgba(11,15,25,.5);
  border: 1px solid rgba(255,255,255,.015);
  border-radius: 1rem;
  padding: 1rem 1rem;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
}
.lp-footer-left { flex: 1; }
.lp-footer-left p { font-size: .7rem; }
.lp-footer-social {
  display: flex;
  gap: .45rem;
}
.lp-footer-social a {
  width: 30px;
  height: 30px;
  background: rgba(139,92,246,.15);
  border: 1px solid rgba(139,92,246,.45);
  border-radius: .6rem;
  display: grid;
  place-items: center;
  color: #fff;
}
.lp-footer-right { width: 330px; }
.lp-footer-games {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
}
.lp-footer-games span {
  background: rgba(15,23,42,.25);
  border-radius: .5rem;
  padding: .2rem .55rem .3rem .55rem;
  font-size: .63rem;
}
.lp-footer-pay {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
}
.lp-footer-pay-item {
  background: rgba(15,23,42,.35);
  border-radius: .5rem;
  padding: .35rem .55rem;
  display: grid;
  place-items: center;
  min-height: 34px;
}
.lp-footer-pay-item img {
  height: 20px;
  object-fit: contain;
}

.lp-footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid rgba(255,255,255,.01);
  margin-top: .6rem;
  padding-top: .45rem;
  font-size: .65rem;
  color: rgba(236,242,255,.25);
}
.lp-footer-links {
  display: flex;
  gap: .65rem;
}
.lp-footer-links a {
  color: rgba(236,242,255,.55);
  text-decoration: none;
}

/* mini footer dari base */
.lp-footer-mini {
  background: transparent;
  border-top: 0;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 991px) {
  .lp-carousel-shell { height: 300px; }
  .lp-carousel__item { width: 85%; height: 88%; }
  .lp-footer-card { flex-direction: column; }
  .lp-footer-right { width: 100%; }
}
@media (max-width: 768px) {
  .lp-flash-wrapper { padding-inline: 1rem; }
  .lp-menu-tabs { overflow-x: auto; white-space: nowrap; }
  .lp-footer-bottom { flex-direction: column; gap: .5rem; align-items: flex-start; }
}
@media (max-width: 575px) {
  .lp-carousel-shell { height: 270px; }
  .lp-carousel__item,
  .lp-carousel__item.is-active {
    width: 92%;
    height: 92%;
    transform: translate(-50%, -50%) scale(1);
  }
  .lp-carousel__item.is-prev,
  .lp-carousel__item.is-next { display: none; }
  .lp-carousel__nav--prev { left: 1rem; }
  .lp-carousel__nav--next { right: 1rem; }
}

/* ===== BREADCRUMB / ARTICLE ===== */
.lp-breadcrumb {
  font-size: .7rem;
  color: rgba(226,232,255,.45);
  display: flex;
  gap: .35rem;
}
.lp-breadcrumb a {
  color: rgba(226,232,255,.75);
  text-decoration: none;
}

.lp-article-title {
  font-size: 1.55rem;
  font-weight: 700;
  max-width: 700px;
}
.lp-article-meta {
  font-size: .7rem;
  color: rgba(226,232,255,.45);
}

.lp-article-detail {
  margin-top: .8rem;
}
.lp-article-layout {
  display: grid;
  grid-template-columns: 1.1fr .45fr;
  gap: 1rem;
}
.lp-article-main {
  background: rgba(12,16,25,.5);
  border: 1px solid rgba(255,255,255,.015);
  border-radius: 1rem;
  padding: .9rem .95rem 1.1rem .95rem;
}
.lp-article-cover {
  width: 100%;
  border-radius: .7rem;
  margin-bottom: .7rem;
}
.lp-article-body {
  font-size: .8rem;
  line-height: 1.6;
  color: rgba(248,250,252,.9);
}
.lp-article-body h2,
.lp-article-body h3 {
  margin-top: .8rem;
  margin-bottom: .35rem;
}
.lp-article-share {
  margin-top: 1rem;
  display: flex;
  gap: .4rem;
  align-items: center;
}
.lp-article-share a {
  width: 30px;
  height: 30px;
  background: rgba(139,92,246,.15);
  border: 1px solid rgba(139,92,246,.35);
  border-radius: .5rem;
  display: grid;
  place-items: center;
  color: #fff;
}

.lp-article-side {
  background: rgba(12,16,25,.25);
  border: 1px solid rgba(255,255,255,.01);
  border-radius: 1rem;
  padding: .75rem .75rem;
  height: fit-content;
}
.lp-article-side-list {
  display: flex;
  flex-direction: column;
  gap: .65rem;
}
.lp-article-side-item {
  display: flex;
  gap: .45rem;
  text-decoration: none;
  color: #fff;
}
.lp-article-side-item img {
  width: 58px;
  height: 40px;
  object-fit: cover;
  border-radius: .4rem;
}
.lp-article-side-item .title {
  font-size: .68rem;
  line-height: 1.2;
}
.lp-article-side-item .date {
  font-size: .6rem;
  color: rgba(226,232,255,.35);
}

/* list artikel lebih rapat */
.lp-article-card--list .lp-article-excerpt {
  font-size: .68rem;
  color: rgba(226,232,255,.65);
  margin-bottom: .35rem;
}
.lp-article-read {
  font-size: .65rem;
  color: var(--purple);
  text-decoration: none;
}

@media (max-width: 991px) {
  .lp-article-layout {
    grid-template-columns: 1fr;
  }
}

/* ===== HOVER EFEK UNTUK KARTU ARTIKEL ===== */
.lp-article-card {
  position: relative;
  background: rgba(12,16,25,.5);
  border: 1px solid rgba(139,92,246,0);  /* awalnya transparan */
  border-radius: 1rem;
  overflow: hidden;
  transition: border .15s ease, box-shadow .15s ease, transform .15s ease;
  cursor: pointer;
}

.lp-article-card:hover {
  border: 1px solid rgba(139,92,246,1); /* ungu */
  box-shadow: 0 0 0 3px rgba(139,92,246,.18); /* ring ungu lembut */
  transform: translateY(-2px);
}

.lp-article-card img,
.lp-article-placeholder {
  border-bottom: 1px solid rgba(255,255,255,.01);
}

/* kalau mau garis cuma di kiri: aktifkan ini dan matikan yg atas */
.lp-article-card.line-left:hover {
  border: 1px solid rgba(139,92,246,0);
  box-shadow: inset 3px 0 0 0 rgba(139,92,246,1);
}

/* ================= KATEGORI CEPAT / PRODUK ================= */
.lp-quick {
  margin-top: 1.3rem;
}

.lp-quick-tabs {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  margin-bottom: .75rem;
}

.lp-quick-tabs button {
  background: rgba(12,16,25,.3);
  border: 1px solid rgba(255,255,255,.02);
  border-radius: .75rem;
  color: #fff;
  font-size: .72rem;
  padding: .4rem .9rem .45rem .6rem;
  display: flex;
  align-items: center;
  gap: .45rem;
  cursor: pointer;
  transition: .15s ease;
}

.lp-quick-tabs button .icon {
  width: 26px;
  height: 26px;
  border-radius: .65rem;
  background: rgba(139,92,246,.14);
  display: grid;
  place-items: center;
  font-size: .9rem;
}

.lp-quick-tabs button.active {
  background: rgba(139,92,246,.28);
  border-color: rgba(139,92,246,.55);
  box-shadow: 0 10px 25px rgba(139,92,246,.2);
}

/* grid kartu */
.lp-quick-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: .75rem;
}

.lp-quick-card {
  position: relative;
  overflow: hidden;
  background: radial-gradient(circle at top, rgba(139,92,246,.14), rgba(9,11,18,.35));
  border: 1px solid rgba(139,92,246,0);
  border-radius: 1rem;
  min-height: 115px;
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .7rem .8rem;
  transition: .15s ease;
  cursor: pointer;
}

.lp-quick-card:hover {
  border-color: rgba(139,92,246,.9);
  box-shadow: 0 16px 30px rgba(0,0,0,.25);
  transform: translateY(-2px);
}

.lp-quick-bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top, rgba(139,92,246,.15), rgba(6,8,16,0));
  background-size: cover;
  background-position: center;
  opacity: .35;
  pointer-events: none;
}

.lp-quick-icon {
  position: relative;
  z-index: 2;
  width: 54px;
  height: 54px;
  border-radius: 1rem;
  background: rgba(6,8,16,.65);
  border: 1px solid rgba(255,255,255,.02);
  display: grid;
  place-items: center;
  overflow: hidden;
  flex: 0 0 54px;
}

.lp-quick-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lp-quick-icon i {
  font-size: 1.35rem;
  color: #fff;
}

.lp-quick-body {
  position: relative;
  z-index: 2;
  min-width: 0;
}

.lp-quick-body .tag {
  font-size: .6rem;
  background: rgba(6,8,16,.35);
  border: 1px solid rgba(255,255,255,.02);
  display: inline-block;
  padding: .1rem .5rem;
  border-radius: 999px;
  margin-bottom: .25rem;
  color: rgba(236,242,255,.75);
}

.lp-quick-body h3 {
  font-size: .8rem;
  margin-bottom: .1rem;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.lp-quick-body .sub {
  font-size: .62rem;
  color: rgba(236,242,255,.5);
}

/* responsive */
@media (max-width: 575px) {
  .lp-quick-tabs {
    overflow-x: auto;
    white-space: nowrap;
    padding-bottom: .2rem;
  }
  .lp-quick-card {
    min-height: 110px;
  }
}

/* ======== PERKUAT WARNA TEKS DI LANDING ======== */

/* warna dasar teks */
.lp-body {
  color: rgba(248, 250, 252, 0.95);
}

/* judul section */
.lp-section-title,
.lp-hero-title,
.lp-article-title {
  color: rgba(255, 255, 255, 0.98);
}

/* text di kartu artikel */
.lp-article-content h3,
.lp-article-content p,
.lp-article-date {
  color: rgba(248, 250, 252, 0.96);
}

/* tag kecil di artikel */
.lp-article-tags span {
  color: rgba(248, 250, 252, 0.9);
  background: rgba(139, 92, 246, 0.18);
  border-color: rgba(139, 92, 246, 0.22);
}

/* text di kartu kategori atas */
.lp-quick-body h3 {
  color: rgba(255, 255, 255, 0.97);
}
.lp-quick-body .sub {
  color: rgba(236, 242, 255, 0.78);
}

/* info footer */
.lp-footer,
.lp-footer p,
.lp-footer a {
  color: rgba(245, 247, 252, 0.85);
}

/* artikel list & detail */
.lp-article-body {
  color: rgba(248, 250, 252, 0.92);
}

/* label kecil (alamat, WA, email) di footer bawah */
.lp-footer .small,
.lp-footer small {
  color: rgba(248, 250, 252, 0.7);
}

/* tombol outline tetap kontras */
.lp-btn-primary-outline {
  border-color: rgba(248, 250, 252, 0.5);
  color: #fff;
}
.lp-btn-primary-outline:hover {
  background: rgba(139, 92, 246, 0.3);
  border-color: rgba(139, 92, 246, 0.6);
}

/* teks di dalam kartu artikel horizontal (yang panjang) */
.lp-articles .lp-article-card {
  color: rgba(248, 250, 252, 0.95);
}

/* ================= FOOTER PANEL (UNGU) ================= */
.lp-footer-panel {
  background: rgba(9, 11, 18, 0.4);
  border-top: 1px solid rgba(139, 92, 246, 0.08);
  margin-top: 1.5rem;
}

.lp-footer-panel__inner {
  display: flex;
  gap: 1.5rem;
  justify-content: space-between;
  padding: 1.25rem 0 1.5rem 0;
}

.lp-footer-left {
  max-width: 480px;
}

.lp-footer-left h4 {
  color: rgba(255, 255, 255, 0.99);
  font-weight: 700;
}

.lp-footer-desc {
  color: rgba(238, 241, 252, 0.88);
  font-size: .75rem;
  line-height: 1.5;
}

.lp-footer-label {
  color: rgba(255, 255, 255, 0.85);
  font-size: .7rem;
  font-weight: 500;
}

.lp-footer-social {
  display: flex;
  gap: .6rem;
}
.lp-footer-social a {
  width: 30px;
  height: 30px;
  border-radius: .5rem;
  background: rgba(139, 92, 246, 0.14);
  border: 1px solid rgba(139, 92, 246, 0.25);
  display: grid;
  place-items: center;
  color: #fff;
  transition: .15s;
}
.lp-footer-social a:hover {
  background: rgba(139, 92, 246, 0.6);
}

.lp-footer-contact {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .35rem;
  font-size: .7rem;
  color: rgba(243, 244, 246, 0.9);
}
.lp-footer-contact li i {
  margin-right: .35rem;
  color: rgba(191, 164, 255, 1);
}

/* kanan */
.lp-footer-right {
  flex: 0 0 360px;
  display: grid;
  gap: 1.1rem;
}

.lp-footer-group h5 {
  font-size: .75rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.92);
  margin-bottom: .45rem;
}

.lp-footer-games {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}
.lp-footer-game {
  width: 105px;
  height: 48px;
  border-radius: .7rem;
  overflow: hidden;
  background: rgba(6, 8, 16, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.03);
}
.lp-footer-game img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Pembayaran */
.lp-footer-pay {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}
.lp-footer-pay-item {
  background: #fff;
  border-radius: .5rem;
  padding: .35rem .45rem;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lp-footer-pay-item img {
  height: 28px;
  object-fit: contain;
}

/* bottom bar */
.lp-footer-bottom {
  border-top: 1px solid rgba(139, 92, 246, 0.12);
  background: rgba(5, 6, 11, 0.3);
  padding: .45rem 0;
}
.lp-footer-bottom__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  font-size: .65rem;
  color: rgba(255, 255, 255, 0.8);
}
.lp-footer-links {
  display: flex;
  gap: .8rem;
}
.lp-footer-links a {
  color: rgba(196, 190, 255, 0.85);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .25rem;
}
.lp-footer-links a::before {
  content: "•";
  color: rgba(139, 92, 246, 1);
}

/* responsive footer */
@media (max-width: 992px) {
  .lp-footer-panel__inner {
    flex-direction: column;
  }
  .lp-footer-right {
    flex: 1 1 auto;
  }
}
@media (max-width: 575px) {
  .lp-footer-games {
    gap: .4rem;
  }
  .lp-footer-game {
    width: calc(50% - .25rem);
  }
  .lp-footer-bottom__inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* slider wrapper */
.lp-footer-slider {
  background: rgba(6, 8, 16, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.02);
  border-radius: .7rem;
  overflow: hidden;
  position: relative;
  max-width: 360px;           /* <== kunci: cuma segini */
  /* boleh 340-380px kalau mau */
}

.lp-footer-track {
  display: flex;
  gap: .55rem;
  padding: .35rem .5rem;
  transition: transform .25s ease;
  will-change: transform;
}

/* tampilkan 3 item saja */
.lp-footer-slide {
  flex: 0 0 calc((100% - 1.1rem) / 3);   /* 3 item dalam 1 row */
  height: 50px;
  border-radius: .6rem;
  overflow: hidden;
  background: rgba(11, 13, 20, .6);
  border: 1px solid rgba(255,255,255,.01);
  display: flex;
  align-items: center;
  justify-content: center;
}
.lp-footer-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* payment slide */
.lp-footer-pay-slide {
  background: #fff;
}
.lp-footer-pay-slide img {
  object-fit: contain;
  padding: .2rem .4rem;
}

.lp-footer-nav {
  display: flex;
  gap: .4rem;
}
.lp-footer-nav .footer-prev,
.lp-footer-nav .footer-next {
  width: 26px;
  height: 26px;
  border: 0;
  border-radius: .55rem;
  background: rgba(139, 92, 246, .15);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: .7rem;
  cursor: pointer;
  transition: .15s ease;
}
.lp-footer-nav .footer-prev:hover,
.lp-footer-nav .footer-next:hover {
  background: rgba(139, 92, 246, .6);
}

/* mobile */
@media (max-width: 575px) {
  .lp-footer-slider {
    max-width: 100%;
  }
  .lp-footer-slide {
    flex: 0 0 calc((100% - .7rem) / 2); /* di HP 2 aja biar gede */
  }
}

/* ===== BESARKAN KOTAK ARTIKEL ===== */
.lp-articles .lp-article-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: .9rem;
}

.lp-article-card {
  min-height: 210px;                 /* ⬅️ tadinya pendek, kita tinggikan */
  display: flex;
  flex-direction: column;
}

.lp-article-card img,
.lp-article-placeholder {
  height: 300px;                     /* ⬅️ gambar lebih tinggi */
  max-height: none;
}

.lp-article-content {
  flex: 1 1 auto;
  padding: .7rem .8rem .75rem .8rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: .35rem;
}

.lp-article-content h3 {
  font-size: .9rem;
  line-height: 1.25;
}

.lp-article-date {
  margin-top: auto;                  /* ⬅️ tanggal nempel di bawah */
  font-size: .68rem;
  color: rgba(244, 244, 255, .6);
}

/* kalau mau lebih tinggi lagi tinggal ubah 210px -> 230/240 */
/* ============ ARTICLE DETAIL PAGE (ungu) ============ */
.lp-article-head {
  margin-top: 1rem;
}

.lp-breadcrumb {
  display: flex;
  gap: .35rem;
  font-size: .65rem;
  align-items: center;
  color: rgba(244, 244, 255, .55);
}
.lp-breadcrumb a {
  color: rgba(244, 244, 255, .75);
  text-decoration: none;
}
.lp-breadcrumb a:hover {
  color: #fff;
}

.lp-article-top {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  flex-wrap: wrap;
}

.lp-article-tags {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
}
.lp-article-tags span {
  background: rgba(139, 92, 246, .12);
  border: 1px solid rgba(139, 92, 246, .6);
  color: #fff;
  font-size: .62rem;
  border-radius: .6rem;
  padding: .15rem .55rem .2rem .55rem;
}

.lp-article-title-detail {
  font-size: 1.5rem;
  font-weight: 700;
  color: rgba(255,255,255,.98);
  margin-bottom: .25rem;
}

.lp-article-meta {
  font-size: .7rem;
  color: rgba(238,240,255,.6);
}

.lp-article-share-inline .lp-share-btns {
  display: flex;
  gap: .35rem;
}
.lp-share-btns a {
  width: 28px;
  height: 28px;
  border-radius: .55rem;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: .8rem;
}
.lp-share-btns a.fb { background: rgba(24,119,242,.25); border: 1px solid rgba(24,119,242,.4); }
.lp-share-btns a.wa { background: rgba(37,211,102,.25); border: 1px solid rgba(37,211,102,.35); }
.lp-share-btns a.tw { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); }

/* layout 2 kolom */
.lp-article-detail {
  margin-top: 1.15rem;
}
.lp-article-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 1.25rem;
  align-items: flex-start;
}

/* konten utama */
.lp-article-main {
  background: radial-gradient(circle at top, rgba(15,23,42,.45), rgba(6,8,16,.08));
  border: 1px solid rgba(139,92,246,.1);
  border-radius: 1rem;
  padding: .9rem .95rem 1rem .95rem;
}

.lp-article-cover-wrap {
  background: rgba(3,5,10,.35);
  border: 1px solid rgba(139,92,246,.12);
  border-radius: .9rem;
  overflow: hidden;
  margin-bottom: .8rem;
}
.lp-article-cover {
  width: 100%;
  height: 240px;              /* <-- gambar tinggi kayak contoh kamu */
  object-fit: cover;
  display: block;
}

.lp-article-body {
  color: rgba(249,249,255,.93);
  font-size: .76rem;
  line-height: 1.6;
}
.lp-article-body h2,
.lp-article-body h3,
.lp-article-body h4 {
  color: #fff;
  margin-top: 1.1rem;
}
.lp-article-body p {
  margin-bottom: .5rem;
}
.lp-article-body a {
  color: rgba(191,164,255,1);
  text-decoration: underline;
}

.lp-article-share-bottom {
  margin-top: 1rem;
  background: rgba(6,8,16,.3);
  border: 1px solid rgba(255,255,255,.01);
  border-radius: .75rem;
  padding: .5rem .6rem;
  display: inline-block;
}

/* sidebar */
.lp-article-side {
  background: rgba(6,8,16,.35);
  border: 1px solid rgba(139,92,246,.08);
  border-radius: 1rem;
  padding: .7rem .7rem 1rem .7rem;
}
.lp-side-title {
  font-size: .8rem;
  font-weight: 600;
  color: rgba(255,255,255,.95);
  margin-bottom: .55rem;
}
.lp-article-side-list {
  display: grid;
  gap: .55rem;
}
.lp-article-side-item {
  display: flex;
  gap: .55rem;
  background: rgba(4,6,12,.12);
  border: 1px solid rgba(255,255,255,0);
  border-radius: .75rem;
  padding: .4rem .45rem;
  text-decoration: none;
  transition: .15s ease;
}
.lp-article-side-item:hover {
  border-color: rgba(139,92,246,.55);
  background: rgba(139,92,246,.05);
}
.lp-article-side-item .thumb {
  width: 85px;
  height: 48px;
  border-radius: .6rem;
  overflow: hidden;
  flex: 0 0 85px;
  background: rgba(255,255,255,.03);
}
.lp-article-side-item .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lp-article-side-item .info {
  min-width: 0;
}
.lp-article-side-item .info .tags {
  display: flex;
  gap: .25rem;
}
.lp-article-side-item .info .tags span {
  background: rgba(139,92,246,.14);
  border: 1px solid rgba(139,92,246,.2);
  border-radius: 999px;
  padding: .05rem .5rem;
  font-size: .55rem;
  color: #fff;
}
.lp-article-side-item .info .title {
  font-size: .7rem;
  color: #fff;
  margin-bottom: .15rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.lp-article-side-item .info .date {
  font-size: .6rem;
  color: rgba(236,236,236,.5);
}

/* responsive */
@media (max-width: 992px) {
  .lp-article-layout {
    grid-template-columns: 1fr;
  }
  .lp-article-side {
    order: 2;
  }
  .lp-article-main {
    order: 1;
  }
}
@media (max-width: 575px) {
  .lp-article-cover {
    height: 210px;
  }
  .lp-article-top {
    flex-direction: column;
    align-items: flex-start;
  }
  .lp-article-share-inline {
    margin-top: .5rem;
  }
}

.lp-products .lp-prod-card {
  background: #fff;
  border-radius: 1rem;
  padding: 1rem 1rem 1.1rem;
  box-shadow: 0 12px 30px rgba(38, 13, 66, 0.05);
  height: 100%;
  position: relative;
  border: 1px solid rgba(137, 82, 255, 0.04);
}

.lp-products .lp-prod-card--outline {
  border: 1px solid rgba(140, 102, 255, .35);
  background: rgba(246, 243, 255, .4);
}

.lp-prod-badge {
  position: absolute;
  top: .6rem;
  right: .6rem;
  background: linear-gradient(120deg, #ff6f4e, #ff9356);
  color: #fff;
  font-size: .65rem;
  padding: .25rem .6rem;
  border-radius: 999px;
}

.lp-prod-title {
  font-size: .9rem;
  font-weight: 600;
  margin-bottom: .25rem;
}

.lp-prod-sub {
  font-size: .7rem;
  color: #7b6f99;
}

.lp-prod-price {
  font-size: .78rem;
  color: #2b134d;
}

/* =========================================
   CARD PRODUK (TERLARIS & TERPOPULER)
   samain tampilannya
   ========================================= */
.lp-products {
  margin-top: 1.35rem;
}

/* gaya card utama */
.lp-products .lp-prod-card {
  background: radial-gradient(circle at top, rgba(139,92,246,.35), rgba(9,11,18,.15));
  border: 1px solid rgba(139,92,246,.16);
  border-radius: 1.1rem;
  display: flex;
  flex-direction: column;
  height: 100%;
  backdrop-filter: blur(3px);
  box-shadow: 0 15px 35px rgba(0,0,0,.15);
}

/* TERPOPULER pakai gaya yg sama persis */
.lp-products--popular .lp-prod-card {
  background: radial-gradient(circle at top, rgba(139,92,246,.35), rgba(9,11,18,.15));
  border: 1px solid rgba(139,92,246,.16);
}

/* header icon */
.lp-prod-thumb {
  height: 95px;
  display: flex;
  align-items: flex-start;
  padding: .75rem .8rem 0 .8rem;
  position: relative;
}

/* kotak icon */
.lp-thumb {
  width: 52px;
  height: 52px;
  border-radius: 1rem;
  display: grid;
  place-items: center;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.21);
}
.lp-thumb img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}

/* badge laris */
.lp-products--terlaris .lp-prod-badge {
  position: absolute;
  top: .75rem;
  right: .75rem;
  background: linear-gradient(120deg, #ff7355, #ff9b55);
  color: #fff;
  font-size: .62rem;
  padding: .25rem .6rem .3rem;
  border-radius: 999px;
  box-shadow: 0 9px 20px rgba(255,115,85,.35);
}

/* body */
.lp-prod-body {
  padding: .25rem .8rem .85rem .8rem;
  display: flex;
  flex-direction: column;
  gap: .25rem;
  flex: 1;
}

.lp-prod-title {
  font-size: .85rem;
  font-weight: 600;
  color: #fff;
  line-height: 1.1;
}
.lp-prod-sub {
  font-size: .63rem;
  color: rgba(226,232,255,.55);
}
.lp-prod-price {
  font-size: .68rem;
  color: rgba(255,255,255,.95);
  margin-top: .25rem;
}
.lp-prod-price strong { color: #fff; }

/* button */
.lp-prod-btn {
  margin-top: .55rem;
  width: 100%;
  background: linear-gradient(130deg, #7c5cff 0%, #6366f1 100%);
  border-radius: .7rem;
  color: #fff;
  border: none;
  text-align: center;
  font-size: .72rem;
  padding: .35rem .45rem .5rem;
  text-decoration: none;
  font-weight: 500;
}

/* tombol "Lihat semua layanan" di kanan atas */
.lp-link-btn {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .3rem .85rem .35rem;
  border: 1px solid rgba(248,250,252,.25);
  border-radius: 999px;
  font-size: .68rem;
  color: #fff;
  background: rgba(15,23,42,.12);
  text-decoration: none;
  transition: .15s ease;
}
.lp-link-btn:hover {
  background: rgba(139,92,246,.38);
  border-color: rgba(139,92,246,.6);
}

/* warna per platform */
.lp-thumb--fb { background: radial-gradient(circle, #fff 0%, #d9e5ff 45%, #2d5fff 90%); }
.lp-thumb--ig { background: radial-gradient(circle at 30% 30%, #fed576 0%, #f47133 35%, #bc3081 60%, #4c63d2 100%); }
.lp-thumb--tt { background: radial-gradient(circle, #111 0%, #0ff 40%, #ff0050 100%); }
.lp-thumb--yt { background: radial-gradient(circle, #fff 0%, #ff0000 80%); }
.lp-thumb--ml { background: linear-gradient(160deg, #fbd66b 0%, #edc268 40%, #443344 100%); }
.lp-thumb--default { background: radial-gradient(circle, #ffffff 0%, #d7ccff 100%); }

@media (max-width: 575px) {
  .lp-products .lp-prod-card {
    border-radius: 1rem;
  }
  .lp-prod-thumb {
    height: 82px;
  }
}