/* ════════════════════════════════════════════════════
   HALAMAN PRINT SUBLIMASI — style-sublimasi.css
   Enqueue via functions.php pada template ini saja
════════════════════════════════════════════════════ */

/* ── CSS Variables inherit dari parent theme ───── */
:root {
  --sub-orange: #F97316;
  --sub-navy:   #0F172A;
  --sub-gold:   #FBBF24;
  --sub-cream:  #FFFBF5;
  --sub-dark2:  #1E293B;
  --sub-radius: 16px;
  --sub-shadow: 0 8px 32px rgba(15,23,42,.12);
  /* Fallback jika parent theme vars belum ter-load */
  --font-display: 'Barlow Condensed', sans-serif;
  --container: 1200px;
  --section-py: 80px;
}

/* Override sk- base classes needed for this template */
.sk-container { width: 100%; max-width: 1200px; margin-inline: auto; padding-inline: 24px; box-sizing: border-box; }
.sk-container--narrow { max-width: 800px; margin-inline: auto; padding-inline: 24px; }
.sk-section { padding-block: 80px; }
.sk-section--dark { background: #0F172A; }
.sk-section-header { text-align: center; max-width: 640px; margin: 0 auto 56px; }
.sk-section-header h2 { margin-bottom: 12px; font-size: clamp(1.6rem,3vw,2.4rem); }
.sk-section-header p { color: #666; }
.sk-section--dark .sk-section-header h2 { color: #fff; }
.sk-section--dark .sk-section-header p { color: rgba(255,255,255,.6); }
.sk-eyebrow { display: inline-block; font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: #F97316; margin-bottom: 10px; }
.sk-btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 28px; border-radius: 50px; font-weight: 700; font-size: .9rem; text-decoration: none; cursor: pointer; border: 2px solid transparent; transition: all .2s; white-space: nowrap; }
.sk-btn-primary { background: #F97316; color: #fff; border-color: #F97316; }
.sk-btn-primary:hover { background: #ea6a0a; color: #fff; transform: translateY(-2px); }
.sk-btn-outline { background: transparent; color: #F97316; border-color: #F97316; }
.sk-btn-outline:hover { background: #F97316; color: #fff; }
.sk-btn-sm { padding: 8px 18px; font-size: .8rem; }
.sk-btn-full { width: 100%; justify-content: center; }
.sk-faq-item { border-bottom: 1px solid #e5e7eb; }
.sk-faq-question { width: 100%; background: none; border: none; text-align: left; padding: 18px 0; font-size: 1rem; font-weight: 600; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 12px; color: #0F172A; font-family: inherit; }
.sk-faq-question:hover { color: #F97316; }
.sk-faq-answer { max-height: 0; overflow: hidden; transition: max-height .35s ease, padding-bottom .35s ease; }
.sk-faq-answer p { color: #555; line-height: 1.7; font-size: .9rem; margin: 0; padding-bottom: 4px; }
.sk-faq-item.active .sk-faq-answer { max-height: 300px; padding-bottom: 20px; }
.sk-faq-item.active .sk-faq-icon i { transform: rotate(45deg); }
.sk-faq-icon i { transition: transform .3s; display: inline-block; color: #F97316; }
.sk-breadcrumb ol { display: flex; align-items: center; gap: 8px; list-style: none; padding: 0; margin: 0; font-size: .8rem; color: rgba(255,255,255,.5); }
.sk-breadcrumb ol li+li::before { content: '/'; margin-right: 8px; }
.sk-breadcrumb a { color: rgba(255,255,255,.6); text-decoration: none; }
/* AOS */
.js [data-aos] { opacity: 0; transform: translateY(28px); transition: opacity .6s ease, transform .6s ease; }
.js [data-aos].aos-animate { opacity: 1; transform: translateY(0); }
.js [data-aos="fade-right"] { transform: translateX(-28px); opacity: 0; }
.js [data-aos="fade-right"].aos-animate { transform: translateX(0); opacity: 1; }
.js [data-aos="fade-left"] { transform: translateX(28px); opacity: 0; }
.js [data-aos="fade-left"].aos-animate { transform: translateX(0); opacity: 1; }

/* ════════════════════════════════════════════════════
   1. HERO
════════════════════════════════════════════════════ */
.sub-hero {
  min-height: 100vh;
  background: var(--sub-navy);
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 120px 0 60px;
  overflow: hidden;
}
.sub-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(15,23,42,.95) 0%, rgba(15,23,42,.75) 60%, rgba(249,115,22,.15) 100%);
  z-index: 0;
}
.sub-hero__pattern {
  position: absolute; inset: 0; z-index: 0; opacity: .04;
  background-image: repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 0, transparent 50%);
  background-size: 20px 20px;
}
.sub-hero__inner {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 60px;
  align-items: center;
}
.sub-hero__left h1 {
  font-size: clamp(2.4rem, 5vw, 4rem);
  color: #fff;
  line-height: 1.05;
  margin: 16px 0 20px;
  font-family: var(--font-display, 'Barlow Condensed', sans-serif);
  font-weight: 800;
}
.sub-hero__left h1 em {
  font-style: italic;
  color: var(--sub-orange);
}
.sub-hero__lead {
  color: rgba(255,255,255,.78);
  font-size: 1.05rem;
  line-height: 1.7;
  margin-bottom: 28px;
  max-width: 540px;
}
.sub-hero__badges { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; }
.sub-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .8px;
  padding: 6px 14px; border-radius: 30px;
}
.sub-pill--gold   { background: var(--sub-gold); color: var(--sub-navy); }
.sub-pill--outline { border: 1.5px solid rgba(255,255,255,.3); color: rgba(255,255,255,.7); }

.sub-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 20px; }
.sub-btn-hero  { font-size: 1rem; padding: 14px 28px; }
.sub-btn-hero-2 { border-color: rgba(255,255,255,.3); color: rgba(255,255,255,.8); }
.sub-btn-hero-2:hover { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.6); }
.sub-hero__note { font-size: .8rem; color: rgba(255,255,255,.45); display: flex; align-items: center; gap: 6px; }

.sub-hero__card-wrap {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.sub-hero__feat-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px;
  padding: 20px 16px;
  display: flex; align-items: center; gap: 12px;
  backdrop-filter: blur(8px);
  transition: border-color .2s, background .2s;
}
.sub-hero__feat-card:hover {
  border-color: rgba(249,115,22,.4);
  background: rgba(249,115,22,.08);
}
.sub-hfc__icon {
  width: 42px; height: 42px;
  background: rgba(249,115,22,.15);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--sub-orange); font-size: 1.1rem; flex-shrink: 0;
}
.sub-hfc__text strong { display: block; font-size: .875rem; color: #fff; margin-bottom: 2px; }
.sub-hfc__text span   { font-size: .75rem; color: rgba(255,255,255,.5); }

/* ════════════════════════════════════════════════════
   2. STATS STRIP
════════════════════════════════════════════════════ */
.sub-stats {
  background: linear-gradient(90deg, var(--sub-orange), #ea580c);
  padding: 36px 0;
}
.sub-stats__grid {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 0;
}
.sub-stat {
  text-align: center; padding: 16px 12px;
  border-right: 1px solid rgba(255,255,255,.2);
}
.sub-stat:last-child { border-right: none; }
.sub-stat__num {
  display: block;
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 900; color: #fff;
  font-family: var(--font-display, 'Barlow Condensed', sans-serif);
  line-height: 1;
}
.sub-stat__unit {
  display: inline-block; font-size: .75rem;
  color: rgba(255,255,255,.7); margin-left: 3px;
}
.sub-stat p { font-size: .8rem; color: rgba(255,255,255,.75); margin: 6px 0 0; }

/* ════════════════════════════════════════════════════
   3. INTRO — APA ITU SUBLIMASI
════════════════════════════════════════════════════ */
.sub-intro__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center;
}
.sub-intro__img { position: relative; }
.sub-intro__img img {
  width: 100%; border-radius: 20px;
  box-shadow: var(--sub-shadow);
}
.sub-intro__badge-float {
  position: absolute; bottom: -20px; right: -20px;
  background: var(--sub-orange); color: #fff;
  border-radius: 14px; padding: 14px 18px;
  display: flex; align-items: center; gap: 12px;
  box-shadow: 0 8px 24px rgba(249,115,22,.4);
  min-width: 220px;
}
.sub-intro__badge-float > i { font-size: 1.5rem; flex-shrink: 0; }
.sub-intro__badge-float strong { display: block; font-size: .875rem; }
.sub-intro__badge-float small  { font-size: .75rem; opacity: .85; }
.sub-intro__content { padding-left: 20px; }
.sub-intro__content h2 { margin-bottom: 16px; }

.sub-compare {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 28px;
}
.sub-compare__col {
  border-radius: 12px; padding: 18px;
}
.sub-compare__col--bad  { background: #FEF2F2; border: 1px solid #FECACA; }
.sub-compare__col--good { background: #F0FDF4; border: 1px solid #86EFAC; }
.sub-compare__col strong {
  display: flex; align-items: center; gap: 6px;
  font-size: .875rem; margin-bottom: 10px;
}
.sub-compare__col--bad  strong { color: #DC2626; }
.sub-compare__col--good strong { color: #16A34A; }
.sub-compare__col ul { list-style: none; padding: 0; margin: 0; }
.sub-compare__col ul li {
  font-size: .82rem; padding: 3px 0;
  color: #444; line-height: 1.4;
}

/* ════════════════════════════════════════════════════
   4. KEUNGGULAN
════════════════════════════════════════════════════ */
.sub-unggulan__grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 48px;
}
.sub-unggulan__card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--sub-radius); padding: 32px;
  transition: border-color .2s, background .2s, transform .2s;
}
.sub-unggulan__card:hover {
  border-color: rgba(249,115,22,.35);
  background: rgba(249,115,22,.06);
  transform: translateY(-4px);
}
.sub-unggulan__icon {
  width: 56px; height: 56px;
  background: rgba(249,115,22,.15);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  color: var(--sub-orange); font-size: 1.4rem; margin-bottom: 18px;
}
.sub-unggulan__card h3 { color: #fff; font-size: 1.05rem; margin-bottom: 10px; }
.sub-unggulan__card p  { color: rgba(255,255,255,.6); font-size: .875rem; line-height: 1.6; margin: 0; }

/* ════════════════════════════════════════════════════
   5. PRODUK GRID
════════════════════════════════════════════════════ */
.sub-produk__grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 48px;
}
.sub-produk__card {
  background: #fff; border-radius: var(--sub-radius);
  box-shadow: var(--sub-shadow); overflow: hidden;
  transition: transform .3s, box-shadow .3s;
}
.sub-produk__card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(15,23,42,.16); }

.sub-produk__img {
  height: 220px; overflow: hidden; position: relative;
  background: var(--sub-cream);
}
.sub-produk__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; display: block; }
.sub-produk__card:hover .sub-produk__img img { transform: scale(1.06); }
.sub-produk__overlay {
  position: absolute; inset: 0;
  background: rgba(15,23,42,.7);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s;
}
.sub-produk__card:hover .sub-produk__overlay { opacity: 1; }

.sub-produk__body { padding: 24px; }
.sub-produk__icon {
  width: 44px; height: 44px;
  background: rgba(249,115,22,.1); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--sub-orange); font-size: 1.1rem; margin-bottom: 12px;
}
.sub-produk__body h3 { font-size: 1rem; margin-bottom: 8px; }
.sub-produk__body p  { font-size: .85rem; color: #666; line-height: 1.6; margin-bottom: 14px; }
.sub-produk__specs { list-style: none; padding: 0; margin: 0; }
.sub-produk__specs li {
  font-size: .8rem; padding: 3px 0;
  display: flex; align-items: center; gap: 6px; color: #555;
}
.sub-produk__specs li i { color: var(--sub-orange); font-size: .7rem; }

/* ════════════════════════════════════════════════════
   6. KAPASITAS (ORANGE)
════════════════════════════════════════════════════ */
.sub-kapasitas {
  background: linear-gradient(135deg, var(--sub-orange) 0%, #c2410c 100%);
  padding: 80px 0; position: relative; overflow: hidden;
}
.sub-kapasitas__bg-text {
  position: absolute; right: -60px; top: 50%;
  transform: translateY(-50%);
  font-size: clamp(12rem, 22vw, 20rem);
  font-weight: 900; color: rgba(255,255,255,.06);
  font-family: var(--font-display, sans-serif);
  line-height: 1; pointer-events: none; user-select: none;
}
.sub-kapasitas__grid {
  display: grid; grid-template-columns: 1fr 480px; gap: 60px;
  align-items: center; position: relative; z-index: 2;
}
.sub-kapasitas__content h2 {
  color: #fff; font-size: clamp(1.8rem, 3.5vw, 2.8rem); margin-bottom: 16px;
}
.sub-kapasitas__content p { color: rgba(255,255,255,.85); line-height: 1.7; margin-bottom: 28px; }
.sub-kap__specs {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 32px;
}
.sub-kap__spec-item {
  display: flex; align-items: flex-start; gap: 10px;
  background: rgba(255,255,255,.12); border-radius: 10px; padding: 12px;
}
.sub-kap__spec-item i { color: #fff; margin-top: 2px; flex-shrink: 0; }
.sub-kap__spec-item small { display: block; font-size: .7rem; color: rgba(255,255,255,.65); text-transform: uppercase; letter-spacing: .5px; }
.sub-kap__spec-item strong { font-size: .875rem; color: #fff; }
.sub-btn-white {
  background: #fff; color: var(--sub-orange); border: 2px solid #fff; border-radius: 50px;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 28px; font-weight: 700; font-size: .9rem; text-decoration: none;
  transition: all .2s;
}
.sub-btn-white:hover { background: var(--sub-navy); color: #fff; border-color: var(--sub-navy); transform: translateY(-2px); }

.sub-kapasitas__img { position: relative; }
.sub-kapasitas__img img { width: 100%; border-radius: 16px; box-shadow: 0 20px 60px rgba(0,0,0,.3); }
.sub-kapasitas__num-badge {
  position: absolute; top: -16px; left: -16px;
  background: var(--sub-navy); color: #fff;
  border-radius: 14px; padding: 14px 20px;
  text-align: center;
  box-shadow: 0 8px 24px rgba(15,23,42,.4);
}
.sub-kapasitas__num-badge .sk-counter-num {
  display: block; font-size: 2rem; font-weight: 900; color: var(--sub-orange);
  font-family: var(--font-display, sans-serif); line-height: 1;
}
.sub-kapasitas__num-badge small { font-size: .7rem; color: rgba(255,255,255,.6); }

/* ════════════════════════════════════════════════════
   7. SPESIFIKASI
════════════════════════════════════════════════════ */
.sub-spek__grid {
  display: grid; grid-template-columns: 1fr 380px; gap: 48px; align-items: start; margin-top: 40px;
}
.sub-spek__table {
  width: 100%; border-collapse: collapse;
  border-radius: var(--sub-radius); overflow: hidden;
  box-shadow: var(--sub-shadow);
}
.sub-spek__table thead th {
  background: var(--sub-navy); color: #fff;
  padding: 14px 20px; text-align: left; font-size: .875rem;
  text-transform: uppercase; letter-spacing: .5px;
}
.sub-spek__table tbody tr { border-bottom: 1px solid #f0f0f0; }
.sub-spek__table tbody tr:last-child { border-bottom: none; }
.sub-spek__table tbody tr:nth-child(even) { background: #FAFAFA; }
.sub-spek__table tbody td { padding: 12px 20px; font-size: .875rem; }
.sub-spek__table tbody td:first-child { font-weight: 600; color: var(--sub-navy); width: 40%; }
.sub-spek__info { display: flex; flex-direction: column; gap: 16px; }
.sub-spek__tip {
  background: var(--sub-cream); border-radius: 12px; padding: 18px;
  border-left: 3px solid var(--sub-orange);
  display: flex; gap: 14px;
}
.sub-spek__tip-icon {
  width: 38px; height: 38px; flex-shrink: 0;
  background: rgba(249,115,22,.12); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--sub-orange); font-size: .95rem;
}
.sub-spek__tip strong { display: block; font-size: .875rem; margin-bottom: 4px; }
.sub-spek__tip p { font-size: .8rem; color: #666; margin: 0; line-height: 1.5; }

/* ════════════════════════════════════════════════════
   8. ALUR PESAN
════════════════════════════════════════════════════ */
.sub-alur__steps {
  display: grid; grid-template-columns: repeat(5,1fr); gap: 16px;
  margin-top: 48px; position: relative;
}
.sub-alur__steps::before {
  content: '';
  position: absolute; top: 50px; left: 10%; right: 10%;
  height: 2px; background: rgba(249,115,22,.2); z-index: 0;
}
.sub-alur__step { text-align: center; position: relative; z-index: 1; }
.sub-alur__num {
  font-size: .65rem; font-weight: 700; color: var(--sub-orange);
  text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px;
}
.sub-alur__icon {
  width: 64px; height: 64px;
  background: rgba(255,255,255,.07);
  border: 2px solid rgba(249,115,22,.3);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 14px; font-size: 1.3rem; color: var(--sub-orange);
  transition: background .2s, border-color .2s;
}
.sub-alur__step:hover .sub-alur__icon {
  background: rgba(249,115,22,.15);
  border-color: var(--sub-orange);
}
.sub-alur__step h3 { color: #fff; font-size: .95rem; margin-bottom: 8px; }
.sub-alur__step p  { color: rgba(255,255,255,.55); font-size: .8rem; line-height: 1.5; }

/* ════════════════════════════════════════════════════
   9. GALERI
════════════════════════════════════════════════════ */
.sub-galeri__grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  grid-auto-rows: 220px;
  gap: 12px; margin-top: 40px;
}
.sub-galeri__item { border-radius: 12px; overflow: hidden; position: relative; cursor: pointer; }
.sub-galeri__item:nth-child(1) { grid-column: span 2; }
.sub-galeri__item a { display: block; width: 100%; height: 100%; }
.sub-galeri__item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; display: block; }
.sub-galeri__item:hover img { transform: scale(1.08); }
.sub-galeri__overlay {
  position: absolute; inset: 0;
  background: rgba(15,23,42,.6);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 1.5rem;
  opacity: 0; transition: opacity .3s;
}
.sub-galeri__item:hover .sub-galeri__overlay { opacity: 1; }
.sub-galeri__placeholder-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 12px;
}

/* ════════════════════════════════════════════════════
   10. HARGA
════════════════════════════════════════════════════ */
.sub-harga__grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 48px;
}
.sub-harga__card {
  border-radius: 20px; padding: 36px 28px; position: relative;
  transition: transform .25s, box-shadow .25s;
}
.sub-harga__card:hover { transform: translateY(-6px); box-shadow: 0 20px 48px rgba(15,23,42,.15); }
.sub-harga__card--outline { border: 2px solid #e5e7eb; background: #fff; }
.sub-harga__card--primary { background: var(--sub-navy); color: #fff; border: 2px solid var(--sub-navy); }
.sub-harga__badge {
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--sub-orange); color: #fff;
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  padding: 4px 16px; border-radius: 20px; letter-spacing: .5px;
  white-space: nowrap;
}
.sub-harga__card h3 {
  font-size: 1.2rem; margin-bottom: 6px;
}
.sub-harga__card--primary h3 { color: #fff; }
.sub-harga__range {
  display: inline-block; background: rgba(249,115,22,.12);
  color: var(--sub-orange); font-weight: 700; font-size: .9rem;
  padding: 4px 12px; border-radius: 20px; margin-bottom: 20px;
}
.sub-harga__card--primary .sub-harga__range { background: rgba(249,115,22,.2); }
.sub-harga__fitur { list-style: none; padding: 0; margin: 0 0 24px; }
.sub-harga__fitur li {
  padding: 8px 0; border-bottom: 1px solid rgba(0,0,0,.06);
  display: flex; align-items: center; gap: 8px; font-size: .875rem;
}
.sub-harga__card--primary .sub-harga__fitur li { border-bottom-color: rgba(255,255,255,.1); color: rgba(255,255,255,.85); }
.sub-harga__fitur li:last-child { border-bottom: none; }
.sub-harga__fitur li i { color: var(--sub-orange); font-size: .75rem; flex-shrink: 0; }

/* ════════════════════════════════════════════════════
   11. FAQ (reuse sk-faq from theme)
════════════════════════════════════════════════════ */
.sub-faq { background: var(--sub-cream); }

/* ════════════════════════════════════════════════════
   12. CTA FINAL
════════════════════════════════════════════════════ */
.sub-cta-final {
  background: var(--sub-navy);
  padding: 100px 0;
  text-align: center;
  position: relative; overflow: hidden;
}
.sub-cta-final__pattern {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 20% 50%, rgba(249,115,22,.15) 0%, transparent 50%),
                    radial-gradient(circle at 80% 50%, rgba(251,191,36,.08) 0%, transparent 50%);
  z-index: 0;
}
.sub-cta-final__inner { position: relative; z-index: 2; max-width: 680px; margin: 0 auto; }
.sub-cta-final__icon {
  width: 80px; height: 80px;
  background: rgba(249,115,22,.15);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 24px;
  font-size: 2rem; color: var(--sub-orange);
}
.sub-cta-final__inner h2 {
  color: #fff;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.15; margin-bottom: 20px;
}
.sub-cta-final__inner h2 em { font-style: italic; color: var(--sub-orange); }
.sub-cta-final__inner p { color: rgba(255,255,255,.7); font-size: 1.05rem; margin-bottom: 36px; line-height: 1.7; }
.sub-btn-xl { font-size: 1.05rem; padding: 16px 36px; }
.sub-cta-final__note {
  display: flex; justify-content: center; gap: 24px;
  margin-top: 20px; flex-wrap: wrap;
}
.sub-cta-final__note span { font-size: .8rem; color: rgba(255,255,255,.45); display: flex; align-items: center; gap: 6px; }

/* ════════════════════════════════════════════════════
   PLACEHOLDERS (before images uploaded)
════════════════════════════════════════════════════ */
.sub-img-placeholder {
  width: 100%; aspect-ratio: 4/3;
  background: linear-gradient(135deg, #f1f5f9, #e2e8f0);
  border-radius: 20px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; color: #94a3b8;
}
.sub-img-placeholder i   { font-size: 3rem; }
.sub-img-placeholder span { font-size: .875rem; }
.sub-img-placeholder--card {
  aspect-ratio: unset; height: 100%;
  border-radius: 0; background: #f8fafc;
}
.sub-img-placeholder--dark {
  border-radius: 16px; aspect-ratio: 4/3;
  background: rgba(255,255,255,.08); color: rgba(255,255,255,.3);
}
.sub-gal-ph {
  height: 200px; border-radius: 12px;
  background: #f1f5f9; border: 2px dashed #e2e8f0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; color: #94a3b8;
}
.sub-gal-ph i { font-size: 1.8rem; }
.sub-gal-ph span { font-size: .75rem; }

/* ════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .sub-hero__inner         { grid-template-columns: 1fr; gap: 40px; }
  .sub-hero__right         { display: none; }
  .sub-intro__grid         { grid-template-columns: 1fr; gap: 40px; }
  .sub-intro__content      { padding-left: 0; }
  .sub-intro__badge-float  { position: static; margin-top: 16px; border-radius: 12px; }
  .sub-unggulan__grid      { grid-template-columns: repeat(2,1fr); }
  .sub-produk__grid        { grid-template-columns: repeat(2,1fr); }
  .sub-kapasitas__grid     { grid-template-columns: 1fr; }
  .sub-kapasitas__img      { order: -1; }
  .sub-kapasitas__num-badge { position: static; display: inline-block; margin-bottom: 16px; }
  .sub-spek__grid          { grid-template-columns: 1fr; }
  .sub-alur__steps         { grid-template-columns: repeat(3,1fr); }
  .sub-alur__steps::before { display: none; }
  .sub-harga__grid         { grid-template-columns: repeat(2,1fr); }
  .sub-stats__grid         { grid-template-columns: repeat(2,1fr); }
  .sub-galeri__grid        { grid-template-columns: repeat(2,1fr); }
  .sub-galeri__item:nth-child(1) { grid-column: span 1; }
}
@media (max-width: 768px) {
  .sub-hero { padding: 100px 0 48px; }
  .sub-hero__left h1 { font-size: 2.2rem; }
  .sub-unggulan__grid  { grid-template-columns: 1fr; }
  .sub-produk__grid    { grid-template-columns: 1fr; }
  .sub-alur__steps     { grid-template-columns: 1fr 1fr; }
  .sub-harga__grid     { grid-template-columns: 1fr; }
  .sub-compare         { grid-template-columns: 1fr; }
  .sub-kap__specs      { grid-template-columns: 1fr; }
  .sub-hero__card-wrap { grid-template-columns: 1fr 1fr; }
  .sub-galeri__grid    { grid-template-columns: 1fr; grid-auto-rows: 200px; }
  .sub-cta-final       { padding: 72px 0; }
  .sub-cta-final__note { flex-direction: column; align-items: center; gap: 10px; }
  .sub-stats__grid     { grid-template-columns: repeat(2,1fr); }
  .sub-stat            { border-right: none; border-bottom: 1px solid rgba(255,255,255,.15); }
  .sub-stat:nth-child(even) { border-left: 1px solid rgba(255,255,255,.15); }
}
@media (max-width: 480px) {
  .sub-hero__actions    { flex-direction: column; }
  .sub-hero__card-wrap  { grid-template-columns: 1fr; }
  .sub-alur__steps      { grid-template-columns: 1fr; }
  .sub-stats__grid      { grid-template-columns: 1fr 1fr; }
  .sk-container--narrow { padding-inline: 16px; }
  .sub-spek__table tbody td,
  .sub-spek__table thead th { padding: 10px 12px; font-size: .8rem; }
}
