﻿/* =========================================================
   BBGTK JABAR â€” Design System
   Brand: #067ac1 (blue) Â· #f9a703 (gold) Â· #ffffff
   Font: Montserrat
   ========================================================= */

/* --- Google Fonts loaded via <link> in _Layout head for parallel fetching ---
   (@import here would create a 4-request critical chain: HTML â†’ CSS â†’ Fonts CSS â†’ WOFF2) */

/* =========================================================
   1. DESIGN TOKENS
   ========================================================= */
:root {
  /* Brand */
  --clr-blue:        #067ac1;
  --clr-blue-dark:   #044f7e;
  --clr-blue-deeper: #033a5d;
  --clr-blue-light:  #2196d3;
  --clr-blue-pale:   #dbeafe;
  --clr-blue-glass:  rgba(6,122,193,0.05);

  --clr-gold:        #f9a703;
  --clr-gold-dark:   #d48a00;
  --clr-gold-light:  #ffc947;
  --clr-gold-pale:   #fff8e6;

  --clr-white:       #ffffff;
  --clr-off-white:   #f9fafb;
  --clr-surface:     #f3f4f6;
  --clr-border:      #e5e7eb;
  --clr-border-dark: #d1d5db;

  /* Text */
  --clr-text-primary:   #111827;
  --clr-text-secondary: #4b5563;
  --clr-text-muted:     #6b7280;   /* WCAG AA: 4.79:1 on white (was #9ca3af = 2.56:1 fail) */
  --clr-text-inverse:   #ffffff;

  /* Dark BG */
  --clr-dark:       #0f172a;
  --clr-dark-card:  #1e293b;
  --clr-dark-nav:   rgba(15,23,42,0.97);

  /* Gradients */
  --grad-primary:  linear-gradient(135deg, #067ac1 0%, #0558a0 100%);
  --grad-hero:     linear-gradient(135deg, #0f172a 0%, #067ac1 55%, #2196d3 100%);
  --grad-gold:     linear-gradient(135deg, #f9a703 0%, #d48a00 100%);
  --grad-overlay:  linear-gradient(180deg, rgba(15,23,42,0.85) 0%, rgba(6,122,193,0.65) 100%);
  --grad-card:     linear-gradient(145deg, #ffffff 0%, #f9fafb 100%);
  --grad-section:  linear-gradient(180deg, #f9fafb 0%, #ffffff 100%);

  /* Shadows */
  --shadow-sm:    0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:    0 4px 16px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.05);
  --shadow-lg:    0 8px 32px rgba(0,0,0,0.1), 0 4px 12px rgba(0,0,0,0.06);
  --shadow-xl:    0 20px 60px rgba(0,0,0,0.12), 0 8px 24px rgba(0,0,0,0.08);
  --shadow-gold:  0 4px 20px rgba(249,167,3,0.3);
  --shadow-card:  0 1px 4px rgba(0,0,0,0.06), 0 2px 10px rgba(0,0,0,0.05);
  --shadow-nav:   0 4px 24px rgba(0,0,0,0.14);

  /* Typography */
  --font-primary: 'Montserrat', sans-serif;
  --fs-xs:    0.75rem;
  --fs-sm:    0.875rem;
  --fs-base:  1rem;
  --fs-md:    1.125rem;
  --fs-lg:    1.25rem;
  --fs-xl:    1.5rem;
  --fs-2xl:   1.875rem;
  --fs-3xl:   2.25rem;
  --fs-4xl:   2.75rem;
  --fs-5xl:   3.5rem;
  --fs-hero:  clamp(2.5rem, 5vw, 4.5rem);

  --fw-light:   300;
  --fw-regular: 400;
  --fw-medium:  500;
  --fw-semi:    600;
  --fw-bold:    700;
  --fw-extra:   800;
  --fw-black:   900;

  --lh-tight:   1.2;
  --lh-snug:    1.35;
  --lh-normal:  1.6;
  --lh-relaxed: 1.75;

  --ls-tight:  -0.025em;
  --ls-normal: -0.01em;
  --ls-wide:    0.05em;
  --ls-wider:   0.1em;

  /* Spacing */
  --sp-1:  0.25rem;
  --sp-2:  0.5rem;
  --sp-3:  0.75rem;
  --sp-4:  1rem;
  --sp-5:  1.25rem;
  --sp-6:  1.5rem;
  --sp-8:  2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;
  --sp-32: 8rem;

  /* Layout */
  --container-max: 1280px;
  --container-xl:  1400px;
  --nav-height:    80px;

  /* Radius */
  --radius-sm:   0.375rem;
  --radius-md:   0.75rem;
  --radius-lg:   1rem;
  --radius-xl:   1.5rem;
  --radius-2xl:  2rem;
  --radius-full: 9999px;

  /* Transitions */
  --ease-out:    cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.45, 0, 0.55, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --t-fast:   0.15s;
  --t-normal: 0.3s;
  --t-slow:   0.5s;
  --t-slower: 0.7s;

  /* Z-index */
  --z-nav:      1000;
  --z-dropdown: 1100;
  --z-modal:    2000;
  --z-toast:    3000;
}

/* =========================================================
   2. RESET & BASE
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-primary);
  font-size: var(--fs-base);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  color: var(--clr-text-primary);
  background: var(--clr-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: inherit; }

/* =========================================================
   3. TYPOGRAPHY
   ========================================================= */
h1, h2, h3, h4, h5, h6 {
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  color: var(--clr-text-primary);
}
h1 { font-size: var(--fs-4xl); font-weight: var(--fw-extra); }
h2 { font-size: var(--fs-3xl); }
h3 { font-size: var(--fs-2xl); }
h4 { font-size: var(--fs-xl); }
h5 { font-size: var(--fs-lg); }
h6 { font-size: var(--fs-md); }
p  { line-height: var(--lh-relaxed); color: var(--clr-text-secondary); }

.text-gradient {
  background: var(--grad-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.text-gradient-gold {
  background: var(--grad-gold);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.section-label {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-blue);
  margin-bottom: var(--sp-4);
}
.section-label::before {
  content: '';
  display: block;
  width: 24px; height: 3px;
  background: var(--grad-gold);
  border-radius: var(--radius-full);
}
.section-label-white { color: rgba(255,255,255,0.8); }
.section-label-white::before { background: var(--clr-gold); }

.section-title {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: var(--fw-extra);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--sp-4);
}
.section-subtitle {
  font-size: var(--fs-md);
  color: var(--clr-text-secondary);
  line-height: var(--lh-relaxed);
  max-width: 640px;
}
.section-subtitle-center { margin: 0 auto; text-align: center; }

/* =========================================================
   4. LAYOUT UTILITIES
   ========================================================= */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--sp-6);
}
.container-xl { max-width: var(--container-xl); }

.section    { padding: var(--sp-24) 0; }
.section-sm { padding: var(--sp-16) 0; }
.section-lg { padding: var(--sp-32) 0; }

.text-center { text-align: center; }
.flex        { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.grid        { display: grid; }

/* =========================================================
   5. NAVIGATION
   ========================================================= */
.site-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-height);
  z-index: var(--z-nav);
  transition:
    background var(--t-normal) var(--ease-out),
    box-shadow var(--t-normal) var(--ease-out),
    height var(--t-normal) var(--ease-out),
    backdrop-filter var(--t-normal) var(--ease-out);
  background: transparent;
  box-shadow: none;
}
.site-nav.scrolled {
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(20px) saturate(200%);
  -webkit-backdrop-filter: blur(20px) saturate(200%);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.05), 0 6px 32px rgba(0, 0, 0, 0.08);
  height: calc(var(--nav-height) - 4px);
}
.site-nav.nav-solid {
  background: var(--clr-white);
  box-shadow: var(--shadow-md);
}

/* Transparent state â€” white text/icons (Home page at top) */
.site-nav:not(.scrolled):not(.nav-solid) .nav-brand-name,
.site-nav:not(.scrolled):not(.nav-solid) .nav-brand-sub {
  color: rgba(255, 255, 255, 0.95);
}
.site-nav:not(.scrolled):not(.nav-solid) .nav-link {
  color: rgba(255, 255, 255, 0.92);
}
.site-nav:not(.scrolled):not(.nav-solid) .nav-link:hover,
.site-nav:not(.scrolled):not(.nav-solid) .nav-link.active {
  color: var(--clr-white);
  background: rgba(255, 255, 255, 0.14);
}
.site-nav:not(.scrolled):not(.nav-solid) .nav-toggle span {
  background: var(--clr-white);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--sp-6);
}
.nav-brand {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-shrink: 0;
}
.nav-brand img {
  height: 60px;
  width: auto;
}
/* Nav saat scrolled jadi sedikit lebih pendek (nav-height - 4px), shrink logo accordingly */
.site-nav.scrolled .nav-brand img { height: 52px; }

/* Section label year suffix (e.g. "Layanan Kami · Tahun 2026 Berjalan") */
.section-label-year {
    font-weight: var(--fw-medium);
    opacity: 0.7;
    letter-spacing: var(--ls-wide);
    margin-left: var(--sp-1);
}

/* Section title year identity (e.g. "Program Prioritas Nasional · Tahun 2026") */
.section-title-year {
    display: inline-block;
    font-size: 0.55em;
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wide);
    color: var(--clr-text-muted);
    vertical-align: middle;
    margin-left: var(--sp-2);
    white-space: nowrap;
}
.section-title[style*="color:#fff"] .section-title-year,
.section-title[style*="color: #fff"] .section-title-year {
    color: rgba(255,255,255,0.6);
}
@media (max-width: 640px) {
    .section-title-year {
        display: block;
        margin-left: 0;
        margin-top: var(--sp-1);
        font-size: 0.7em;
    }
    /* Hilangkan tanda "·" di awal saat sudah pindah baris (look-cleaner) */
    .section-title-year { padding-left: 0; }
}

/* ─── Dual nav logo (white di hero transparan, color saat scrolled/solid) ─── */
.nav-logo--scrolled { display: none; }
.nav-logo--default  { display: block; }
.site-nav.scrolled  .nav-logo--default,
.site-nav.nav-solid .nav-logo--default  { display: none; }
.site-nav.scrolled  .nav-logo--scrolled,
.site-nav.nav-solid .nav-logo--scrolled { display: block; }


/* ─── Program badges di utility bar ──── */
.nav-badges {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
}
.nav-badge {
    height: 28px;   /* fit di utility bar 40px height */
    width: auto;
    object-fit: contain;
    filter: brightness(1.1) drop-shadow(0 1px 2px rgba(0,0,0,0.3));
    transition: opacity var(--t-fast);
}
/* Hide badges di mobile (utility bar sudah hilang via media query atas) — redundant safety */
@media (max-width: 768px) {
    .nav-badges { display: none; }
    /* Logo brand shrink agar tidak mendominasi nav-bar di mobile */
    .nav-brand img,
    .site-nav.scrolled .nav-brand img { height: 44px; }
    .nav-brand img.nav-logo { width: auto; max-width: 200px; }
}
@media (max-width: 480px) {
    .nav-brand img,
    .site-nav.scrolled .nav-brand img { height: 38px; max-width: 170px; }
}
.nav-brand-text { display: flex; flex-direction: column; }
.nav-brand-name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  line-height: 1.2;
  letter-spacing: var(--ls-wide);
  transition: color var(--t-normal) var(--ease-out);
}
.nav-brand-sub {
  font-size: 10px;
  font-weight: var(--fw-medium);
  color: var(--clr-text-muted);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  transition: color var(--t-normal) var(--ease-out);
}

.nav-menu {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}
.nav-item { position: relative; }
.nav-link {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-text-primary);
  letter-spacing: var(--ls-normal);
  border-radius: var(--radius-sm);
  transition: all var(--t-fast) var(--ease-out);
  white-space: nowrap;
  /* soft glassmorphism */
  background: rgba(6,122,193,0.05);
  border: 1px solid rgba(6,122,193,0.08);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.nav-link:hover, .nav-link.active {
  color: var(--clr-blue);
  background: var(--clr-blue-pale);
  border-color: rgba(6,122,193,0.18);
}
/* Glass variant when nav is transparent (homepage hero) */
.site-nav:not(.scrolled):not(.nav-solid) .nav-menu .nav-link {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.13);
}
.site-nav:not(.scrolled):not(.nav-solid) .nav-menu .nav-link:hover,
.site-nav:not(.scrolled):not(.nav-solid) .nav-menu .nav-link.active {
  background: rgba(255,255,255,0.18);
  border-color: rgba(255,255,255,0.25);
  color: #fff;
}
.nav-link .chevron {
  width: 14px; height: 14px;
  transition: transform var(--t-fast) var(--ease-out);
  flex-shrink: 0;
}
.nav-item:hover > .nav-link .chevron { transform: rotate(180deg); }

.nav-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 260px;
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-2);
  box-shadow: var(--shadow-xl);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--t-normal) var(--ease-out);
}
.nav-item:hover > .nav-dropdown,
.nav-item:focus-within > .nav-dropdown,
.nav-item.is-open > .nav-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-dropdown-mega {
  min-width: 520px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.mega-col { padding: var(--sp-2); }
.mega-col-title {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--clr-blue);
  padding: var(--sp-2) var(--sp-3);
  margin-bottom: var(--sp-1);
}

.dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  border-radius: var(--radius-md);
  transition: all var(--t-fast) var(--ease-out);
}
.dropdown-item:hover {
  color: var(--clr-blue);
  background: var(--clr-blue-pale);
}
.dropdown-item::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--clr-blue);
  flex-shrink: 0;
  opacity: 0;
  transform: scale(0);
  transition: all var(--t-fast) var(--ease-out);
}
.dropdown-item:hover::before { opacity: 1; transform: scale(1); }
.dropdown-divider {
  height: 1px;
  background: var(--clr-border);
  margin: var(--sp-2) var(--sp-3);
}

/* nav-actions: search btn + hamburger grouped */
.nav-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

/* Search button in nav */
.nav-search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border-radius: var(--radius-full);
  border: none;
  background: transparent;
  color: var(--clr-text-primary);
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.nav-search-btn:hover {
  background: rgba(6,122,193,0.1);
  color: var(--clr-blue);
  transform: scale(1.08);
}
.site-nav:not(.scrolled):not(.nav-solid) .nav-search-btn {
  color: rgba(255,255,255,0.85);
}
.site-nav:not(.scrolled):not(.nav-solid) .nav-search-btn:hover {
  background: rgba(255,255,255,0.12);
  color: var(--clr-white);
}

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: var(--sp-2);
  cursor: pointer;
}
.nav-toggle span {
  display: block;
  width: 24px; height: 2px;
  background: var(--clr-text-primary);
  border-radius: var(--radius-full);
  transition: all var(--t-normal) var(--ease-out);
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.top-bar {
  background: var(--clr-blue);
  padding: 6px 0;
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.9);
  font-weight: var(--fw-medium);
}
.top-bar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: var(--container-xl);
  margin: 0 auto;
  padding: 0 var(--sp-6);
}
.top-bar-socials { display: flex; align-items: center; gap: var(--sp-3); }
.top-bar-socials a { color: rgba(255,255,255,0.8); transition: color var(--t-fast); }
.top-bar-socials a:hover { color: var(--clr-white); }

/* =========================================================
   6. HERO â€” HOMEPAGE
   ========================================================= */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--clr-dark);
}
.hero-bg {
  position: absolute;
  inset: 0;
  background: var(--grad-hero);
  z-index: 0;
}
.hero-bg-pattern {
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 50%, rgba(6,122,193,0.3) 0%, transparent 50%),
    radial-gradient(circle at 80% 20%, rgba(249,167,3,0.15) 0%, transparent 40%),
    radial-gradient(circle at 60% 80%, rgba(6,122,193,0.2) 0%, transparent 50%);
  z-index: 1;
}
.hero-grid-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  z-index: 1;
}
.hero-content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: calc(var(--nav-height) + var(--sp-12));
  padding-bottom: var(--sp-24);
}
.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background: rgba(249,167,3,0.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(249,167,3,0.5);
  color: var(--clr-gold);
  text-shadow: 0 1px 8px rgba(249,167,3,0.35);
  font-size: var(--fs-sm);
  font-weight: var(--fw-extra);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-6);
}
.hero-title {
  font-size: var(--fs-hero);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  line-height: var(--lh-tight);
  letter-spacing: -0.03em;
  margin-bottom: var(--sp-6);
  max-width: 820px;
  text-shadow: 0 2px 12px rgba(0,0,0,0.5), 0 1px 3px rgba(0,0,0,0.4);
}
.hero-title span { color: var(--clr-gold); }
.hero-subtitle {
  font-size: var(--fs-lg);
  color: rgba(255,255,255,0.92);
  line-height: var(--lh-relaxed);
  max-width: 620px;
  margin-bottom: var(--sp-10);
  font-weight: var(--fw-regular);
  text-shadow: 0 1px 8px rgba(0,0,0,0.55), 0 1px 2px rgba(0,0,0,0.4);
}
.hero-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  flex-wrap: wrap;
  margin-bottom: var(--sp-16);
}
.hero-scroll-indicator {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  color: rgba(255,255,255,0.5);
  font-size: var(--fs-xs);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
}
.scroll-mouse {
  width: 24px; height: 38px;
  border: 2px solid rgba(255,255,255,0.3);
  border-radius: var(--radius-full);
  position: relative;
  flex-shrink: 0;
}
.scroll-mouse::after {
  content: '';
  position: absolute;
  top: 6px; left: 50%;
  transform: translateX(-50%);
  width: 4px; height: 8px;
  background: var(--clr-gold);
  border-radius: var(--radius-full);
  animation: scrollBounce 2s ease-in-out infinite;
}
@keyframes scrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); opacity: 1; }
  60%       { transform: translateX(-50%) translateY(10px); opacity: 0; }
}

.hero-stats-row {
  display: flex;
  gap: var(--sp-1);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-2xl);
  padding: var(--sp-6) var(--sp-8);
  backdrop-filter: blur(10px);
  width: fit-content;
  flex-wrap: wrap;
}
.hero-stat-item {
  padding: var(--sp-3) var(--sp-6);
  text-align: center;
  position: relative;
}
.hero-stat-item:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0; top: 20%; bottom: 20%;
  width: 1px;
  background: rgba(255,255,255,0.15);
}
.hero-stat-number {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  line-height: 1;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 2px;
}
.hero-stat-number sup { font-size: var(--fs-sm); color: var(--clr-gold); }
.hero-stat-label {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.55);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  margin-top: var(--sp-1);
}

/* =========================================================
   7. BUTTONS
   ========================================================= */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-6);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  font-family: var(--font-primary);
  letter-spacing: var(--ls-normal);
  border-radius: var(--radius-full);
  transition: all var(--t-normal) var(--ease-out);
  cursor: pointer;
  border: 2px solid transparent;
  text-decoration: none;
  white-space: nowrap;
}
.btn-icon { width: 18px; height: 18px; flex-shrink: 0; }

.btn-primary {
  background: var(--grad-gold);
  color: var(--clr-dark);
  box-shadow: var(--shadow-gold);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(249,167,3,0.45);
  color: var(--clr-dark);
}
.btn-outline {
  border-color: rgba(255,255,255,0.4);
  color: var(--clr-white);
  background: transparent;
}
.btn-outline:hover {
  border-color: var(--clr-white);
  background: rgba(255,255,255,0.1);
  color: var(--clr-white);
}
.btn-blue {
  background: var(--grad-primary);
  color: var(--clr-white);
  box-shadow: var(--shadow-md);
}
.btn-blue:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
  color: var(--clr-white);
}
.btn-sm  { padding: var(--sp-2) var(--sp-4); font-size: var(--fs-xs); }
.btn-lg  { padding: var(--sp-4) var(--sp-8); font-size: var(--fs-base); }

/* =========================================================
   8. PROGRAM SHOWCASE SECTION (Beranda)
   ========================================================= */
.services-section {
  padding: var(--sp-24) 0;
  background: var(--clr-off-white);
  position: relative;
  overflow: hidden;
}

/* Parallax background orbs â€” subtle on light bg */
.prg-parallax-bg { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.prg-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  will-change: transform;
}
.prg-orb-1 {
  width: 640px; height: 640px;
  background: rgba(6,122,193,0.07);
  top: -180px; right: -120px;
}
.prg-orb-2 {
  width: 500px; height: 500px;
  background: rgba(249,167,3,0.07);
  bottom: -100px; left: -100px;
}
.prg-orb-3 {
  width: 360px; height: 360px;
  background: rgba(6,122,193,0.04);
  top: 50%; left: 35%;
}
.prg-grid-overlay { display: none; }

/* Section header */
.prg-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-8);
  margin-bottom: var(--sp-12);
  flex-wrap: wrap;
}
.prg-header-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-xl);
  padding: var(--sp-5) var(--sp-8);
  flex-shrink: 0;
  box-shadow: var(--shadow-card);
}
.prg-stat-big {
  display: block;
  font-size: var(--fs-4xl);
  font-weight: var(--fw-black);
  color: var(--clr-blue);
  line-height: 1;
  letter-spacing: var(--ls-tight);
}
.prg-stat-label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--clr-text-muted);
  margin-top: var(--sp-2);
}

/* Category cards */
.prg-category-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
  margin-bottom: var(--sp-6);
}
.prg-category-card {
  background: var(--clr-white);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--clr-border);
  display: flex;
  flex-direction: column;
  transition: transform var(--t-normal) var(--ease-out), box-shadow var(--t-normal) var(--ease-out);
}
.prg-category-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.prg-card-blue { border-top: 4px solid var(--clr-blue); }
.prg-card-gold { border-top: 4px solid var(--clr-gold); }

/* Soft-tinted header inside card */
.prg-card-header {
  padding: var(--sp-8) var(--sp-10);
  position: relative;
  overflow: hidden;
}
.prg-card-blue .prg-card-header {
  background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
  border-bottom: 1px solid #bfdbfe;
}
.prg-card-gold .prg-card-header {
  background: linear-gradient(135deg, #fefce8 0%, #fef3c7 100%);
  border-bottom: 1px solid #fde68a;
}
.prg-card-header-deco  { display: none; }
.prg-card-header-deco-2 { display: none; }

.prg-card-type-badge {
  display: inline-flex;
  align-items: center;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  border-radius: var(--radius-full);
  padding: 3px var(--sp-3);
  margin-bottom: var(--sp-4);
}
.prg-card-blue .prg-card-type-badge {
  background: rgba(6,122,193,0.1);
  border: 1px solid rgba(6,122,193,0.25);
  color: var(--clr-blue);
}
.prg-card-gold .prg-card-type-badge {
  background: rgba(180,93,0,0.1);
  border: 1px solid rgba(180,93,0,0.25);
  color: #92400e;
}

.prg-card-count-row {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
  margin-bottom: var(--sp-2);
}
.prg-card-number {
  font-size: clamp(2.5rem, 4vw, 3.5rem);
  font-weight: var(--fw-black);
  line-height: 1;
  letter-spacing: -0.04em;
}
.prg-card-blue .prg-card-number { color: var(--clr-blue); }
.prg-card-gold .prg-card-number { color: #b45309; }

.prg-card-number-label {
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  color: var(--clr-text-muted);
}
.prg-card-title {
  font-size: var(--fs-base);
  font-weight: var(--fw-semi);
  color: var(--clr-text-primary);
  line-height: var(--lh-snug);
  margin-top: 0;
}

/* White body area */
.prg-card-body {
  padding: var(--sp-6) var(--sp-8) var(--sp-8);
  flex: 1;
  display: flex;
  flex-direction: column;
}
.prg-card-list {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.prg-card-list-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  font-weight: var(--fw-medium);
  padding: 13px var(--sp-2);
  border-bottom: 1px solid var(--clr-border);
  text-decoration: none;
  transition: all var(--t-fast);
  line-height: var(--lh-snug);
}
.prg-card-list-item:last-child { border-bottom: none; }
.prg-card-list-item:hover { color: var(--clr-blue); padding-left: var(--sp-2); }
.prg-card-list-item::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
  opacity: 0.5;
  transition: opacity var(--t-fast), transform var(--t-fast);
}
.prg-card-blue .prg-card-list-item::before  { background: var(--clr-blue); }
.prg-card-gold .prg-card-list-item::before  { background: var(--clr-gold-dark); }
.prg-card-list-item:hover::before { opacity: 1; transform: scale(1.4); }
.prg-card-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  text-decoration: none;
  padding: var(--sp-3) var(--sp-5);
  border-radius: var(--radius-full);
  margin-top: var(--sp-5);
  transition: all var(--t-normal) var(--ease-out);
  width: fit-content;
}
.prg-card-blue .prg-card-cta {
  background: transparent;
  color: var(--clr-blue);
  border: 2px solid var(--clr-blue);
}
.prg-card-blue .prg-card-cta:hover {
  background: var(--clr-blue);
  color: var(--clr-white);
  transform: translateX(4px);
}
.prg-card-gold .prg-card-cta {
  background: transparent;
  color: #92400e;
  border: 2px solid var(--clr-gold);
}
.prg-card-gold .prg-card-cta:hover {
  background: var(--clr-gold);
  color: var(--clr-dark);
  transform: translateX(4px);
}
.prg-card-cta svg { width: 14px; height: 14px; }

/* Featured chips row */
.prg-chips-row {
  display: grid;
  grid-template-columns: repeat(var(--service-cols, 3), 1fr);
  gap: var(--sp-4);
}
@media (min-width: 640px)  { .prg-chips-row { --service-cols: 3; } }
@media (min-width: 1024px) { .prg-chips-row { --service-cols: 6; } }

.prg-chip {
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-xl);
  padding: var(--sp-5) var(--sp-4);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-3);
  text-decoration: none;
  transition: all var(--t-normal) var(--ease-out);
  cursor: pointer;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-card);
}
.prg-chip::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--grad-primary);
  opacity: 0;
  transition: opacity var(--t-normal);
}
.prg-chip:hover { transform: translateY(-5px); border-color: var(--clr-blue); box-shadow: var(--shadow-md); }
.prg-chip:hover::before { opacity: 1; }
.prg-chip-icon {
  width: 52px; height: 52px;
  background: var(--clr-blue-pale);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative; z-index: 1;
  transition: background var(--t-normal);
}
.prg-chip-icon svg { width: 24px; height: 24px; color: var(--clr-blue); transition: color var(--t-normal); }
.prg-chip:hover .prg-chip-icon { background: rgba(255,255,255,0.15); }
.prg-chip:hover .prg-chip-icon svg { color: var(--clr-white); }
.prg-chip-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-text-secondary);
  position: relative; z-index: 1;
  transition: color var(--t-normal);
  line-height: var(--lh-snug);
  text-align: center;
}
.prg-chip:hover .prg-chip-label { color: var(--clr-white); }

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .prg-category-grid { grid-template-columns: 1fr; }
  .prg-header { flex-direction: column; align-items: flex-start; }
  .prg-header-stat { flex-direction: row; align-items: center; gap: var(--sp-4); align-self: stretch; }
  .prg-stat-big { font-size: var(--fs-2xl); }
  .prg-card-header { padding: var(--sp-6) var(--sp-8); }
}
@media (max-width: 480px) {
  .prg-chips-row { grid-template-columns: repeat(3, 1fr) !important; }
  .prg-chip { padding: var(--sp-4) var(--sp-3); }
  .prg-chip-icon { width: 44px; height: 44px; }
}

/* Legacy aliases still used elsewhere â€” keep */
.services-grid {
  display: grid;
  grid-template-columns: repeat(var(--service-cols, 3), 1fr);
  gap: var(--sp-6);
  margin-top: var(--sp-12);
}
@media (min-width: 640px)  { .services-grid { --service-cols: 3; } }
@media (min-width: 1024px) { .services-grid { --service-cols: 6; } }
.service-card {
  background: var(--clr-white);
  border-radius: var(--radius-xl);
  padding: var(--sp-8) var(--sp-5);
  text-align: center;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--clr-border);
  transition: all var(--t-normal) var(--ease-out);
  cursor: pointer;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.service-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--grad-primary);
  opacity: 0;
  transition: opacity var(--t-normal) var(--ease-out);
}
.service-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: transparent; }
.service-card:hover::before { opacity: 1; }
.service-icon-wrap {
  width: 64px; height: 64px;
  background: var(--clr-blue-pale);
  border-radius: var(--radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-4);
  transition: background var(--t-normal);
  position: relative;
  z-index: 1;
}
.service-icon-wrap svg { width: 28px; height: 28px; color: var(--clr-blue); transition: color var(--t-normal); }
.service-card:hover .service-icon-wrap { background: rgba(255,255,255,0.15); }
.service-card:hover .service-icon-wrap svg { color: var(--clr-white); }
.service-title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-2);
  position: relative;
  z-index: 1;
  transition: color var(--t-normal);
  line-height: var(--lh-snug);
}
.service-card:hover .service-title { color: var(--clr-white); }

/* =========================================================
   9. STATISTICS
   ========================================================= */
.stats-section {
  padding: var(--sp-24) 0;
  background: var(--grad-primary);
  position: relative;
  overflow: hidden;
}
.stats-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 10% 50%, rgba(255,255,255,0.05) 0%, transparent 40%),
    radial-gradient(circle at 90% 50%, rgba(249,167,3,0.1) 0%, transparent 40%);
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0;
  position: relative;
  z-index: 1;
}
.stat-item {
  text-align: center;
  padding: var(--sp-8) var(--sp-6);
  position: relative;
}
.stat-item:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0; top: 25%; bottom: 25%;
  width: 1px;
  background: rgba(255,255,255,0.15);
}
.stat-number {
  font-size: clamp(2.5rem, 4vw, 3.5rem);
  font-weight: var(--fw-black);
  color: var(--clr-white);
  line-height: 1;
  letter-spacing: var(--ls-tight);
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: var(--sp-1);
  margin-bottom: var(--sp-2);
}
.stat-suffix { font-size: var(--fs-xl); font-weight: var(--fw-bold); color: var(--clr-gold); }
.stat-label {
  font-size: var(--fs-sm);
  color: rgba(255,255,255,0.75);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  line-height: var(--lh-snug);
}

/* =========================================================
   10. BADGE TICKER
   ========================================================= */
.badge-ticker-section {
  position: relative;
  z-index: 10;
  background: var(--clr-blue-deeper);
  padding: var(--sp-5) 0;
  overflow: hidden;
}
.badge-ticker-wrap { display: flex; overflow: hidden; }
.badge-ticker-track {
  display: flex;
  gap: var(--sp-10);
  animation: ticker 35s linear infinite;
  width: max-content;
}
.badge-ticker-track:hover { animation-play-state: paused; }
@keyframes ticker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.badge-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-shrink: 0;
  color: rgba(255,255,255,0.8);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  white-space: nowrap;
}
.badge-item img { height: 36px; width: auto; }
.badge-separator { width: 4px; height: 4px; background: var(--clr-gold); border-radius: 50%; flex-shrink: 0; }

/* =========================================================
   11. NEWS CARDS
   ========================================================= */
.news-section { padding: var(--sp-24) 0; background: var(--clr-white); }
.news-tabs {
  display: flex;
  gap: var(--sp-1);
  margin-bottom: var(--sp-10);
  border-bottom: 2px solid var(--clr-border);
}
.news-tab {
  padding: var(--sp-3) var(--sp-5);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-text-secondary);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all var(--t-fast);
  cursor: pointer;
  border-top: none; border-left: none; border-right: none;
  background: transparent;
  font-family: var(--font-primary);
}
.news-tab.active { color: var(--clr-blue); border-bottom-color: var(--clr-blue); }
.news-tab:hover  { color: var(--clr-blue); }

.news-grid          { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); }
.news-grid-featured { grid-template-columns: 1.4fr 1fr 1fr; }

.news-card {
  background: var(--clr-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--clr-border);
  transition: all var(--t-normal) var(--ease-out);
  display: flex;
  flex-direction: column;
  text-decoration: none;
}
.news-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(6,122,193,0.15);
}
.news-card-img-wrap { overflow: hidden; position: relative; }
.news-card-img { width: 100%; aspect-ratio: 16/9; object-fit: cover; transition: transform var(--t-slow) var(--ease-out); }
.news-card:hover .news-card-img { transform: scale(1.04); }
.news-card-category {
  position: absolute;
  top: var(--sp-3); left: var(--sp-3);
  background: var(--clr-blue);
  color: var(--clr-white);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: var(--radius-full);
}
.news-card-body {
  padding: var(--sp-5);
  flex: 1;
  display: flex;
  flex-direction: column;
}
.news-card-date {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  font-weight: var(--fw-medium);
  margin-bottom: var(--sp-2);
}
.news-card-title {
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  line-height: var(--lh-snug);
  margin-bottom: var(--sp-3);
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-card:hover .news-card-title { color: var(--clr-blue); }
.news-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--clr-border);
  padding-top: var(--sp-3);
  margin-top: auto;
}
.read-more {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-blue);
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  transition: gap var(--t-fast);
}
.read-more:hover { gap: var(--sp-2); }
.read-more svg { width: 14px; height: 14px; }

/* =========================================================
   12. INNER PAGE HERO
   ========================================================= */
.inner-hero {
  background: var(--grad-hero);
  padding: calc(var(--nav-height) + var(--sp-12)) 0 var(--sp-16);
  position: relative;
  overflow: hidden;
}
.inner-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 80% 50%, rgba(249,167,3,0.1) 0%, transparent 50%),
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: auto, 40px 40px, 40px 40px;
}
.inner-hero-content { position: relative; z-index: 1; }
.inner-hero-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-gold);
  margin-bottom: var(--sp-3);
}
.inner-hero-title {
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: var(--fw-extra);
  color: var(--clr-white);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--sp-4);
}
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-top: var(--sp-6);
  font-size: var(--fs-sm);
  color: rgba(255,255,255,0.5);
}
.breadcrumb a { color: rgba(255,255,255,0.7); transition: color var(--t-fast); }
.breadcrumb a:hover { color: var(--clr-gold); }
.breadcrumb-sep { color: rgba(255,255,255,0.3); }
.breadcrumb-current { color: var(--clr-gold); font-weight: var(--fw-semi); }

/* =========================================================
   13. INNER LAYOUT (Sidebar + Content)
   ========================================================= */
.inner-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--sp-10);
  align-items: start;
  padding: var(--sp-16) 0 var(--sp-24);
}
.sidebar { position: sticky; top: calc(var(--nav-height) + var(--sp-6)); }
.sidebar-nav {
  background: var(--clr-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--clr-border);
}
.sidebar-nav-header {
  background: var(--grad-primary);
  padding: var(--sp-5) var(--sp-6);
}
.sidebar-nav-title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--clr-white);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.sidebar-nav-body { padding: var(--sp-3); }
.sidebar-nav-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text-secondary);
  border-radius: var(--radius-md);
  transition: all var(--t-fast);
  text-decoration: none;
}
.sidebar-nav-item::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--clr-border-dark);
  flex-shrink: 0;
  transition: background var(--t-fast);
}
.sidebar-nav-item:hover,
.sidebar-nav-item.active {
  background: var(--clr-blue-pale);
  color: var(--clr-blue);
  font-weight: var(--fw-semi);
}
.sidebar-nav-item:hover::before,
.sidebar-nav-item.active::before { background: var(--clr-blue); }
.sidebar-nav-divider { height: 1px; background: var(--clr-border); margin: var(--sp-2) var(--sp-4); }
.sidebar-nav-group-label {
  font-size: 10px;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--clr-text-muted);
  padding: var(--sp-2) var(--sp-4) var(--sp-1);
}

/* =========================================================
   14. CONTENT AREA
   ========================================================= */
.content-area { min-width: 0; }
.content-card {
  background: var(--clr-white);
  border-radius: var(--radius-xl);
  padding: var(--sp-10);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--clr-border);
  margin-bottom: var(--sp-6);
}
.content-card h2 { margin-bottom: var(--sp-4); font-size: var(--fs-2xl); }
.content-card h3 { margin-bottom: var(--sp-3); font-size: var(--fs-xl); color: var(--clr-blue); margin-top: var(--sp-6); }
.content-card p  { margin-bottom: var(--sp-4); }
.content-card ul, .content-card ol {
  margin: var(--sp-4) 0 var(--sp-4) var(--sp-6);
  list-style: disc;
  color: var(--clr-text-secondary);
  line-height: var(--lh-relaxed);
}
.content-card ul li, .content-card ol li { margin-bottom: var(--sp-2); }
/* Featured image in detail pages â€” full image visible regardless of aspect ratio.
   Portrait & square images are letterboxed against a neutral background instead
   of being cropped. Landscape fills the frame naturally up to max-height. */
.content-image,
.post-cover-img {
  display: block;
  width: 100%;
  max-height: 600px;
  object-fit: contain;
  object-position: center;
  background: var(--clr-surface);
  border-radius: var(--radius-lg);
  margin: var(--sp-6) 0;
}
.post-cover-img { margin: 0 0 2rem; }   /* post detail uses tighter spacing */

.data-capaian-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--sp-4);
  margin: var(--sp-8) 0;
}
.data-capaian-card {
  background: linear-gradient(145deg, var(--clr-blue-pale), var(--clr-white));
  border: 1px solid rgba(6,122,193,0.15);
  border-radius: var(--radius-lg);
  padding: var(--sp-6);
  text-align: center;
  transition: all var(--t-normal) var(--ease-out);
}
.data-capaian-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: var(--clr-blue);
}
.data-capaian-number {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-black);
  color: var(--clr-blue);
  line-height: 1;
  margin-bottom: var(--sp-2);
}
.data-capaian-label {
  font-size: var(--fs-xs);
  color: var(--clr-text-secondary);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
}

/* =========================================================
   15. ARTICLE / NEWS LIST
   ========================================================= */
.article-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-8);
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.search-bar {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-full);
  padding: var(--sp-2) var(--sp-4);
  transition: all var(--t-fast);
  min-width: 280px;
}
.search-bar:focus-within {
  border-color: var(--clr-blue);
  box-shadow: 0 0 0 3px rgba(6,122,193,0.1);
}
.search-bar input { border: none; outline: none; font-size: var(--fs-sm); color: var(--clr-text-primary); background: transparent; flex: 1; font-family: var(--font-primary); }
.search-bar svg  { width: 16px; height: 16px; color: var(--clr-text-muted); flex-shrink: 0; }

/* Date-range filter bar (article category listing) */
.article-filter-bar {
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: var(--sp-3);
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-4) var(--sp-5);
  margin-bottom: var(--sp-5);
}
.article-filter-group { display: flex; flex-direction: column; gap: 4px; min-width: 160px; }
.article-filter-group label {
  font-size: var(--fs-xs); font-weight: var(--fw-semi); color: var(--clr-text-secondary);
  text-transform: uppercase; letter-spacing: .04em;
}
.article-filter-group input[type="date"] {
  font-size: var(--fs-sm); font-family: var(--font-primary);
  border: 1px solid var(--clr-border); border-radius: var(--radius-md);
  padding: .55rem .75rem; color: var(--clr-text-primary); background: var(--clr-white);
  transition: border-color .18s, box-shadow .18s;
}
.article-filter-group input[type="date"]:focus {
  outline: none; border-color: var(--clr-blue);
  box-shadow: 0 0 0 3px rgba(6,122,193,0.12);
}
.article-filter-actions { display: flex; gap: var(--sp-2); margin-left: auto; }
.article-filter-summary {
  font-size: var(--fs-sm); color: var(--clr-text-secondary);
  margin-bottom: var(--sp-4);
}
.article-filter-summary span { display: inline-block; margin-right: var(--sp-2); }
.article-filter-summary strong { color: var(--clr-blue); font-weight: var(--fw-semi); }

@media (max-width: 640px) {
  .article-filter-bar { flex-direction: column; align-items: stretch; }
  .article-filter-group { min-width: 0; }
  .article-filter-actions { margin-left: 0; }
}

.article-list { display: flex; flex-direction: column; gap: var(--sp-4); }
.article-item {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 0;
  background: var(--clr-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--clr-border);
  transition: all var(--t-normal) var(--ease-out);
  text-decoration: none;
}
.article-item:hover {
  transform: translateX(4px);
  box-shadow: var(--shadow-md);
  border-color: rgba(6,122,193,0.2);
}
/* aspect-ratio reserves space pre-load (CLS prevention, Core Web Vitals) */
.article-item-img { width: 100%; height: 100%; min-height: 140px; aspect-ratio: 10 / 7; object-fit: cover; }
.article-item-body { padding: var(--sp-5); }
.article-item-category {
  display: inline-block;
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--clr-blue);
  background: var(--clr-blue-pale);
  padding: 2px 8px;
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-2);
}
.article-item-title {
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  line-height: var(--lh-snug);
  margin-bottom: var(--sp-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.article-item:hover .article-item-title { color: var(--clr-blue); }
.article-item-excerpt {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: var(--sp-3);
  line-height: var(--lh-relaxed);
}
.article-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
}
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  margin-top: var(--sp-10);
}
.page-btn {
  width: 40px; height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-text-secondary);
  border: 1px solid var(--clr-border);
  background: var(--clr-white);
  transition: all var(--t-fast);
  cursor: pointer;
  font-family: var(--font-primary);
}
.page-btn:hover  { border-color: var(--clr-blue); color: var(--clr-blue); }
.page-btn.active { background: var(--clr-blue); color: var(--clr-white); border-color: var(--clr-blue); }
.page-ellipsis {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  color: var(--clr-text-muted);
  font-weight: var(--fw-bold);
}

/* Pagination bar (wraps pagination + info + jump) */
.pagination-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-top: var(--sp-10);
}
.pagination-bar .pagination { margin-top: 0; flex-wrap: wrap; }
.pagination-info {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
}
.pagination-jump {
  display: flex; align-items: center; gap: var(--sp-2);
  font-size: var(--fs-sm);
}
.pagination-jump label { color: var(--clr-text-muted); margin: 0; }
.pagination-jump input {
  width: 70px;
  padding: 6px 10px;
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-md);
  font-size: var(--fs-sm);
  font-family: var(--font-primary);
  text-align: center;
}
.pagination-jump input:focus { outline: none; border-color: var(--clr-blue); }
@media (max-width: 640px) {
  .pagination-bar { justify-content: center; }
  .pagination-info, .pagination-jump { width: 100%; justify-content: center; }
}

/* =========================================================
   16. PROGRAM CARDS
   ========================================================= */
.program-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-6);
  margin-top: var(--sp-10);
}
.program-card {
  background: var(--clr-white);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--clr-border);
  transition: all var(--t-normal) var(--ease-out);
  display: flex;
  flex-direction: column;
  text-decoration: none;
}
.program-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
}
.program-card-accent { height: 5px; background: var(--grad-primary); }
.program-card:nth-child(even) .program-card-accent { background: var(--grad-gold); }
.program-card-body { padding: var(--sp-6); flex: 1; }
.program-card-icon {
  width: 52px; height: 52px;
  background: var(--clr-blue-pale);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-4);
}
.program-card-icon svg { width: 24px; height: 24px; color: var(--clr-blue); }
.program-card-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-2);
  line-height: var(--lh-snug);
}
.program-card:hover .program-card-title { color: var(--clr-blue); }
.program-card-desc {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  line-height: var(--lh-relaxed);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.program-card-footer {
  padding: var(--sp-4) var(--sp-6);
  border-top: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* =========================================================
   17. FORMS
   ========================================================= */
.form-card {
  background: var(--clr-white);
  border-radius: var(--radius-2xl);
  padding: var(--sp-10);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--clr-border);
  max-width: 720px;
  margin: 0 auto;
}
.form-section-title {
  font-size: var(--fs-xl);
  font-weight: var(--fw-extra);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-8);
  padding-bottom: var(--sp-4);
  border-bottom: 3px solid var(--clr-blue);
  display: inline-block;
}
.form-group { margin-bottom: var(--sp-5); }
.form-label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-text-primary);
  margin-bottom: var(--sp-2);
}
.form-label.required::after { content: ' *'; color: #ef4444; }
.form-control {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-sm);
  font-family: var(--font-primary);
  color: var(--clr-text-primary);
  background: var(--clr-off-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-md);
  transition: all var(--t-fast);
  outline: none;
}
.form-control:focus {
  border-color: var(--clr-blue);
  background: var(--clr-white);
  box-shadow: 0 0 0 3px rgba(6,122,193,0.1);
}
.form-control::placeholder { color: var(--clr-text-muted); }
textarea.form-control { resize: vertical; min-height: 140px; }
.form-hint { font-size: var(--fs-xs); color: var(--clr-text-muted); margin-top: var(--sp-1); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); }

/* =========================================================
   18. DOCUMENT LIST (Akuntabilitas / PPID)
   ========================================================= */
.doc-filter-bar {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-8);
  flex-wrap: wrap;
}
.year-filter-btn {
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-text-secondary);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-full);
  background: var(--clr-white);
  transition: all var(--t-fast);
  cursor: pointer;
  font-family: var(--font-primary);
}
.year-filter-btn:hover,
.year-filter-btn.active {
  background: var(--clr-blue);
  color: var(--clr-white);
  border-color: var(--clr-blue);
  box-shadow: var(--shadow-md);
}
.doc-list { display: flex; flex-direction: column; gap: var(--sp-3); }
.doc-item {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  transition: all var(--t-fast);
  cursor: pointer;
  text-decoration: none;
}
.doc-item:hover {
  border-color: var(--clr-blue);
  background: var(--clr-blue-pale);
  transform: translateX(4px);
}
.doc-icon {
  width: 44px; height: 44px;
  background: #fee2e2;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 11px;
  font-weight: var(--fw-black);
  color: #dc2626;
  letter-spacing: 0;
}
.doc-info { flex: 1; min-width: 0; }
.doc-title {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-text-primary);
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.doc-item:hover .doc-title { color: var(--clr-blue); }
.doc-meta { font-size: var(--fs-xs); color: var(--clr-text-muted); }
.doc-download-btn {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-blue);
  padding: var(--sp-2) var(--sp-3);
  border: 1px solid rgba(6,122,193,0.2);
  border-radius: var(--radius-md);
  transition: all var(--t-fast);
  font-family: var(--font-primary);
  background: transparent;
}
.doc-item:hover .doc-download-btn {
  background: var(--clr-blue);
  color: var(--clr-white);
  border-color: var(--clr-blue);
}

/* =========================================================
   19. BOOKSHELF (Majalah)
   ========================================================= */
.bookshelf-wrapper { padding: var(--sp-2) 0 var(--sp-4); }

/* â”€â”€ Per-year shelf section â”€â”€ */
.shelf-section { margin-bottom: 52px; }
.shelf-row + .shelf-row { margin-top: 36px; }

.shelf-year-badge {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 20px;
}
.shelf-year-badge .yr-num {
  font-size: 0.78rem; font-weight: 800; letter-spacing: 0.08em;
  color: var(--clr-blue); background: var(--clr-blue-pale);
  padding: 3px 14px; border-radius: 999px; white-space: nowrap;
}
.shelf-year-badge .yr-line { flex: 1; height: 1px; background: var(--clr-border); }

/* â”€â”€ The row of books sitting on the plank â”€â”€ */
.shelf-row {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  align-items: flex-end;
  padding: 0 4px 22px 4px;
}

/* â”€â”€ Shelf plank â€” modern thin ledge â”€â”€ */
.shelf-plank {
  position: absolute;
  bottom: 0; left: -12px; right: -12px; height: 10px;
  background: #e2e8f0;
  border-radius: 0 0 6px 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,.1), inset 0 1px 0 rgba(255,255,255,.8);
}

/* â”€â”€ Individual book card â”€â”€ */
.book-card {
  display: flex; flex-direction: column; align-items: center;
  width: 180px; flex-shrink: 0;
  transition: transform .32s cubic-bezier(.34,1.56,.64,1);
  transform-origin: bottom center;
}
.book-card--readable { cursor: pointer; }
.book-card:hover { transform: translateY(-22px) scale(1.04); }

/* â”€â”€ Book cover â”€â”€ */
.book-cover {
  width: 180px; height: 252px;
  border-radius: 2px 6px 6px 2px;
  overflow: hidden; position: relative;
  background: var(--clr-blue-pale);
  box-shadow:
    -4px 0 8px rgba(0,0,0,.25),
    4px 8px 22px rgba(0,0,0,.28),
    9px 14px 36px rgba(0,0,0,.15);
}
.book-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* â”€â”€ Spine gradient (left edge dark) â”€â”€ */
.book-spine {
  position: absolute; left: 0; top: 0; bottom: 0; width: 11px; z-index: 1;
  background: linear-gradient(to right,
    rgba(0,0,0,.35) 0%, rgba(0,0,0,.12) 60%, transparent 100%);
  pointer-events: none;
}

/* â”€â”€ Spine highlight (right page edge) â”€â”€ */
.book-cover::after {
  content: '';
  position: absolute; right: 0; top: 0; bottom: 0; width: 4px;
  background: linear-gradient(to left,
    rgba(255,255,255,.18) 0%, transparent 100%);
  pointer-events: none;
}

/* â”€â”€ Hover read overlay â”€â”€ */
.book-overlay {
  position: absolute; inset: 0;
  background: rgba(6,122,193,.74);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 6px; opacity: 0;
  transition: opacity .2s ease;
  color: #fff; font-size: var(--fs-sm); font-weight: var(--fw-semibold);
}
.book-card--readable:hover .book-overlay { opacity: 1; }

/* â”€â”€ Book metadata & actions â”€â”€ */
.book-title {
  margin-top: var(--sp-3); font-size: 12px; font-weight: 700;
  color: var(--clr-text-primary); text-align: center;
  line-height: 1.35; max-width: 180px;
}
.book-year {
  font-size: 10px; color: var(--clr-text-muted);
  text-align: center; margin-top: 2px;
}
.book-actions {
  display: flex; gap: 5px; justify-content: center;
  margin-top: var(--sp-2); flex-wrap: wrap;
}
.book-btn {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 3px 9px; border-radius: 999px; font-size: 10px; font-weight: 600;
  border: none; cursor: pointer; text-decoration: none; transition: background .15s;
}
.book-btn-read         { background: var(--clr-blue-pale); color: var(--clr-blue); }
.book-btn-read:hover   { background: var(--clr-blue); color: #fff; }
.book-btn-download     { background: #e8faf0; color: #16a34a; }
.book-btn-download:hover { background: #16a34a; color: #fff; }

/* â”€â”€ Empty state â”€â”€ */
.shelf-empty {
  padding: 3rem; text-align: center;
  color: var(--clr-text-muted); font-size: var(--fs-sm);
}

/* â”€â”€ Bookshelf wrapper: clean modern â”€â”€ */
.bookshelf-wrapper {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: var(--sp-8) var(--sp-6) var(--sp-4);
}

/* =========================================================
   20. GALLERY
   ========================================================= */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--sp-4);
  margin-top: var(--sp-8);
}
.gallery-item {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  /* Instagram portrait 1080Ã—1350 = 4:5 â€” used by SurveyKepuasan & NilaiIPKP */
  aspect-ratio: 4 / 5;
  cursor: pointer;
  box-shadow: var(--shadow-card);
}
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow); }
.gallery-item:hover img { transform: scale(1.08); }
.gallery-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(4,22,48,0.7) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--t-normal);
  display: flex;
  align-items: flex-end;
  padding: var(--sp-4);
}
.gallery-item:hover .gallery-overlay { opacity: 1; }
.gallery-item-title { color: var(--clr-white); font-size: var(--fs-sm); font-weight: var(--fw-semi); }

/* =========================================================
   21. KEMITRAAN
   ========================================================= */
.partner-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--sp-5);
  margin-top: var(--sp-8);
}
.partner-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding: var(--sp-6);
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-xl);
  transition: all var(--t-normal) var(--ease-out);
  text-align: center;
  min-height: 140px;
  text-decoration: none;
}
.partner-card:hover {
  border-color: var(--clr-blue);
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}
.partner-logo { max-height: 64px; max-width: 140px; object-fit: contain; }
.partner-name { font-size: var(--fs-xs); font-weight: var(--fw-semi); color: var(--clr-text-secondary); }

/* =========================================================
   22. PPID SPECIFIC
   ========================================================= */
.ppid-link-btn {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  transition: all var(--t-normal) var(--ease-out);
  margin-bottom: var(--sp-3);
  text-decoration: none;
}
.ppid-link-btn:hover {
  background: var(--clr-blue-pale);
  border-color: var(--clr-blue);
  transform: translateX(4px);
}
.ppid-link-icon {
  width: 40px; height: 40px;
  background: var(--clr-blue-pale);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ppid-link-icon svg { width: 20px; height: 20px; color: var(--clr-blue); }
.ppid-link-text strong { display: block; font-size: var(--fs-sm); font-weight: var(--fw-semi); color: var(--clr-text-primary); }
.ppid-link-text span  { font-size: var(--fs-xs); color: var(--clr-text-muted); }

/* =========================================================
   23. TAUTAN
   ========================================================= */
.tautan-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--sp-5);
  margin-top: var(--sp-8);
}
.tautan-card {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-5);
  background: var(--clr-white);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-xl);
  transition: all var(--t-normal) var(--ease-out);
  text-decoration: none;
}
.tautan-card:hover {
  border-color: var(--clr-blue);
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}
.tautan-logo { width: 52px; height: 52px; object-fit: contain; flex-shrink: 0; border-radius: var(--radius-md); border: 1px solid var(--clr-border); padding: var(--sp-2); }
.tautan-name { font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--clr-text-primary); margin-bottom: 2px; }
.tautan-url  { font-size: var(--fs-xs); color: var(--clr-text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tautan-card:hover .tautan-name { color: var(--clr-blue); }

/* =========================================================
   24. FOOTER
   ========================================================= */
.site-footer {
  background: linear-gradient(160deg, rgb(29, 73, 173) 0%, rgb(10, 31, 58) 100%);
  color: rgba(255,255,255,0.75);
  padding-top: var(--sp-20);
  position: relative;
  overflow: hidden;
}
.site-footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--clr-blue) 0%, var(--clr-gold) 50%, var(--clr-blue) 100%);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--sp-10);
  padding-bottom: var(--sp-12);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.footer-brand img { height: 52px; width: auto; margin-bottom: var(--sp-4); }
.footer-brand-name { font-size: var(--fs-base); font-weight: var(--fw-bold); color: var(--clr-white); margin-bottom: var(--sp-2); line-height: var(--lh-snug); }
.footer-brand-desc { font-size: var(--fs-sm); line-height: var(--lh-relaxed); color: rgba(255,255,255,0.6); margin-bottom: var(--sp-6); }
.footer-socials { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.social-btn {
  width: 36px; height: 36px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.6);
  transition: all var(--t-fast);
  font-size: 15px;
  text-decoration: none;
}
.social-btn:hover {
  background: var(--clr-blue);
  border-color: var(--clr-blue);
  color: var(--clr-white);
  transform: translateY(-2px);
}
.footer-col-title {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--clr-white);
  margin-bottom: var(--sp-5);
  position: relative;
  padding-bottom: var(--sp-3);
}
.footer-col-title::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 24px; height: 2px;
  background: var(--clr-gold);
  border-radius: var(--radius-full);
}
.footer-links { display: flex; flex-direction: column; gap: var(--sp-2); }
.footer-link {
  font-size: var(--fs-sm);
  color: rgba(255,255,255,0.6);
  transition: color var(--t-fast);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  text-decoration: none;
}
.footer-link:hover { color: var(--clr-white); }
.footer-link::before { content: '\203A'; color: var(--clr-gold); font-weight: var(--fw-bold); }
.footer-contact-item {
  display: flex;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
  font-size: var(--fs-sm);
  color: rgba(255,255,255,0.6);
  align-items: flex-start;
}
.footer-contact-item svg { width: 16px; height: 16px; color: var(--clr-gold); flex-shrink: 0; margin-top: 2px; }
.footer-bottom {
  padding: var(--sp-5) 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-4);
}
.footer-copyright { font-size: var(--fs-xs); color: rgba(255,255,255,0.4); }
.footer-bottom-links { display: flex; gap: var(--sp-6); }
.footer-bottom-links a { font-size: var(--fs-xs); color: rgba(255,255,255,0.4); transition: color var(--t-fast); text-decoration: none; }
.footer-bottom-links a:hover { color: var(--clr-gold); }

/* =========================================================
   25. BACK TO TOP
   ========================================================= */
.back-to-top {
  position: fixed;
  bottom: var(--sp-8);
  right: var(--sp-8);
  width: 46px; height: 46px;
  background: var(--grad-primary);
  color: var(--clr-white);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  pointer-events: none;
  transform: translateY(12px);
  transition: all var(--t-normal) var(--ease-out);
  z-index: var(--z-nav);
  cursor: pointer;
  border: none;
}
.back-to-top.visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
.back-to-top:hover   { transform: translateY(-3px); box-shadow: var(--shadow-xl); }
.back-to-top svg     { width: 20px; height: 20px; }

/* =========================================================
   26. MOBILE MENU
   ========================================================= */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--clr-white);
  z-index: calc(var(--z-nav) - 1);
  transform: translateX(100%);
  transition: transform var(--t-slow) var(--ease-out);
  overflow-y: auto;
  padding: calc(var(--nav-height) + var(--sp-6)) var(--sp-6) var(--sp-10);
}
.mobile-menu.open { transform: translateX(0); }
.mobile-nav-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4) 0;
  font-size: var(--fs-base);
  font-weight: var(--fw-semi);
  color: var(--clr-text-primary);
  border-bottom: 1px solid var(--clr-border);
  cursor: pointer;
  transition: color var(--t-fast);
  text-decoration: none;
}
.mobile-nav-item:hover { color: var(--clr-blue); }
.mobile-submenu { display: none; padding: var(--sp-2) 0 var(--sp-2) var(--sp-4); }
.mobile-submenu.open { display: block; }
.mobile-submenu-item {
  display: block;
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  transition: color var(--t-fast);
  text-decoration: none;
}
.mobile-submenu-item:hover { color: var(--clr-blue); }

/* =========================================================
   27. UTILITIES
   ========================================================= */
.badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: var(--radius-full); font-size: 11px; font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; }
.badge-blue  { background: var(--clr-blue-pale); color: var(--clr-blue); }
/* WCAG AA: solid gold bg + dark text = 8.17:1 (was pale bg + gold-dark text = 2.63:1 fail) */
.badge-gold  { background: var(--clr-gold); color: var(--clr-dark); }
.badge-green { background: #dcfce7; color: #16a34a; }

.divider { height: 1px; background: var(--clr-border); margin: var(--sp-8) 0; }

.accent-line { display: block; width: 48px; height: 4px; background: var(--grad-gold); border-radius: var(--radius-full); margin: var(--sp-3) 0 var(--sp-5); }
.accent-line-center { margin-left: auto; margin-right: auto; }

.no-result { text-align: center; padding: var(--sp-16); color: var(--clr-text-muted); }
.no-result svg { width: 48px; height: 48px; margin: 0 auto var(--sp-4); opacity: 0.3; }

/* =========================================================
   28. RESPONSIVE
   ========================================================= */
@media (max-width: 1200px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--sp-8); }
}
@media (max-width: 1024px) {
  .inner-layout { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .nav-menu { display: none; }
  .nav-toggle { display: flex; }
  .news-grid-featured { grid-template-columns: 1fr 1fr; }
  /* Sidebar becomes horizontal scroll on tablet */
  .sidebar-nav { overflow: hidden; }
  .sidebar-nav-body { display: flex; flex-wrap: wrap; gap: var(--sp-2); padding: var(--sp-4); }
  .sidebar-nav-item { flex-shrink: 0; border-radius: var(--radius-full); padding: var(--sp-2) var(--sp-4); }
  .sidebar-nav-divider, .sidebar-nav-group-label { display: none; }
}
@media (max-width: 768px) {
  :root { --nav-height: 64px; }
  .hero-title    { font-size: clamp(1.75rem, 7vw, 2.75rem); }
  .hero-subtitle { font-size: var(--fs-sm); }
  .hero-stats-row { padding: var(--sp-4); gap: 0; flex-wrap: wrap; justify-content: center; }
  .hero-stat-item { padding: var(--sp-2) var(--sp-3); }
  .hero-stat-item:not(:last-child)::after { display: none; }
  .hero-scroll-indicator { display: none; }
  .news-grid, .news-grid-featured { grid-template-columns: 1fr; }
  .article-item   { grid-template-columns: 1fr; }
  .article-item-img { height: 180px; }
  .form-row       { grid-template-columns: 1fr; }
  .footer-grid    { grid-template-columns: 1fr; gap: var(--sp-6); }
  .top-bar        { display: none; }
  .stats-grid     { grid-template-columns: repeat(2, 1fr); }
  .stat-item:not(:last-child)::after { display: none; }
  .section        { padding: var(--sp-16) 0; }
  .container      { padding: 0 var(--sp-4); }
  .back-to-top    { bottom: var(--sp-5); right: var(--sp-5); }
  .content-card   { padding: var(--sp-6); }
  .inner-hero     { padding: calc(var(--nav-height) + var(--sp-8)) 0 var(--sp-10); }
  .inner-hero-title { font-size: clamp(1.5rem, 6vw, 2.25rem); }
  .inner-layout   { padding: var(--sp-10) 0 var(--sp-16); gap: var(--sp-6); }
  .hero-eyebrow   { font-size: var(--fs-xs); }
  .inner-hero-label { font-size: 10px; }
  .doc-filter-bar { overflow-x: auto; flex-wrap: nowrap; padding-bottom: var(--sp-2); }
  .year-filter-btn { flex-shrink: 0; }
}
@media (max-width: 480px) {
  .services-grid    { grid-template-columns: repeat(2, 1fr) !important; }
  .program-grid     { grid-template-columns: 1fr; }
  .book-card  { width: 130px; }
  .book-cover { width: 130px; height: 182px; }
  .book-title { max-width: 130px; }
  .shelf-row  { gap: 12px; }
  .data-capaian-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-actions     { flex-direction: column; align-items: stretch; }
  .hero-actions .btn { justify-content: center; }
  .gallery-grid     { grid-template-columns: repeat(2, 1fr); }
  .tautan-grid      { grid-template-columns: 1fr; }
  .article-list-header { flex-direction: column; align-items: stretch; }
  .search-bar       { min-width: unset; width: 100%; }
  .content-card     { padding: var(--sp-5); border-radius: var(--radius-lg); }
  .form-card        { padding: var(--sp-6); border-radius: var(--radius-xl); }
  .hero-stats-row   { display: none; }
}

/* =========================================================
   INDEX 2 â€” Alternative Homepage
   ========================================================= */

/* â”€â”€â”€ Â§ 1 Hero â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.i2-hero-content {
  display: flex;
  align-items: center;
  min-height: 100vh;
  padding-top: calc(var(--nav-height) + var(--sp-12));
  padding-bottom: var(--sp-20);
}
.i2-hero-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-10);
}
.i2-hero-text { flex: 1; max-width: 620px; }

/* Floating program-count card */
.i2-hero-card {
  flex-shrink: 0;
  width: 220px;
  background: rgba(255,255,255,0.07);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-2xl);
  padding: var(--sp-6);
  text-align: center;
  color: #fff;
  box-shadow: 0 8px 40px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.1);
  will-change: transform;
}
.i2-hero-card-icon {
  width: 52px; height: 52px;
  background: rgba(6,122,193,0.3);
  border-radius: var(--radius-lg);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--sp-4);
  color: var(--clr-gold);
}
.i2-hero-card-stat {
  font-size: 2.8rem; font-weight: 900; line-height: 1;
  background: linear-gradient(135deg, #fff 0%, var(--clr-gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.i2-hero-card-label {
  font-size: var(--fs-sm); color: rgba(255,255,255,0.65);
  margin-top: var(--sp-1); margin-bottom: var(--sp-4);
}
.i2-hero-card-divider {
  height: 1px; background: rgba(255,255,255,0.12); margin: var(--sp-4) 0;
}
.i2-hero-card-row {
  display: flex; gap: var(--sp-2); justify-content: center; flex-wrap: wrap;
  margin-bottom: var(--sp-5);
}
.i2-hero-card-badge {
  font-size: 0.72rem; font-weight: 700;
  padding: 0.25rem 0.65rem; border-radius: 20px;
}
.i2-hero-card-badge.blue  { background: rgba(6,122,193,0.35); color: #93c5fd; }
.i2-hero-card-badge.gold  { background: rgba(249,167,3,0.25); color: var(--clr-gold); }
.i2-hero-card-link {
  display: block; font-size: var(--fs-sm); font-weight: 700;
  color: var(--clr-gold); text-decoration: none;
  transition: opacity 0.2s;
}
.i2-hero-card-link:hover { opacity: 0.8; }

/* Scroll indicator */
.i2-scroll-indicator {
  position: absolute; bottom: 2.5rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  color: rgba(255,255,255,0.45); font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  z-index: 20; pointer-events: none;
  animation: i2ScrollBounce 2s ease-in-out infinite;
}
.i2-scroll-mouse {
  width: 22px; height: 36px;
  border: 2px solid rgba(255,255,255,0.3); border-radius: 11px;
  display: flex; justify-content: center; padding-top: 6px;
}
.i2-scroll-wheel {
  width: 4px; height: 8px;
  background: rgba(255,255,255,0.5); border-radius: 2px;
  animation: i2WheelScroll 1.8s ease-in-out infinite;
}
@keyframes i2ScrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}
@keyframes i2WheelScroll {
  0%   { opacity: 1; transform: translateY(0); }
  80%  { opacity: 0; transform: translateY(10px); }
  100% { opacity: 0; transform: translateY(0); }
}

/* â”€â”€â”€ Â§ 3 Program Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.i2-programs {
  background: var(--clr-white);
  padding: 5rem 0;
  position: relative; overflow: hidden;
}
.i2-programs-orb {
  position: absolute; border-radius: 50%; pointer-events: none;
  filter: blur(80px); opacity: 0.45; will-change: transform;
}
.i2-prg-orb-a {
  width: 480px; height: 480px; top: -120px; right: -80px;
  background: radial-gradient(circle, rgba(6,122,193,0.12), transparent 70%);
}
.i2-prg-orb-b {
  width: 360px; height: 360px; bottom: -80px; left: -60px;
  background: radial-gradient(circle, rgba(249,167,3,0.12), transparent 70%);
}
.i2-section-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--sp-6); flex-wrap: wrap; margin-bottom: var(--sp-10);
}
.i2-programs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-5);
  margin-bottom: var(--sp-8);
}
.i2-program-card {
  display: flex; flex-direction: column;
  background: var(--clr-off-white);
  border-radius: var(--radius-xl);
  padding: var(--sp-6) var(--sp-5);
  border-left: 3px solid transparent;
  text-decoration: none; color: inherit;
  transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s;
  position: relative; overflow: hidden;
}
.i2-program-card::before {
  content: ''; position: absolute; top: -28px; right: -28px;
  width: 90px; height: 90px;
  background: var(--clr-primary, #067ac1); opacity: 0.04; border-radius: 50%;
  transition: opacity 0.25s;
}
.i2-program-card:hover { border-left-color: var(--clr-blue); box-shadow: var(--shadow-md); transform: translateY(-5px); }
.i2-program-card:hover::before { opacity: 0.08; }
.i2-program-num {
  font-size: 2.2rem; font-weight: 900; line-height: 1;
  color: var(--clr-blue); opacity: 0.15; margin-bottom: var(--sp-3);
}
.i2-program-name { font-size: 0.925rem; font-weight: 700; color: var(--clr-text-primary); margin-bottom: var(--sp-2); line-height: 1.3; }
.i2-program-desc { font-size: 0.8rem; color: var(--clr-text-muted); line-height: 1.65; flex: 1; margin-bottom: var(--sp-4); }
.i2-program-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }
.i2-program-badge {
  font-size: 0.68rem; font-weight: 700;
  padding: 0.22rem 0.6rem; border-radius: 20px;
}
.i2-program-badge.prioritas { background: rgba(6,122,193,0.1); color: var(--clr-blue); }
.i2-program-badge.inovasi   { background: rgba(249,167,3,0.15); color: #a06200; }
.i2-program-arrow {
  display: flex; align-items: center; gap: 4px;
  font-size: 0.78rem; font-weight: 700; color: var(--clr-blue);
  opacity: 0; transition: opacity 0.2s;
}
.i2-program-card:hover .i2-program-arrow { opacity: 1; }

/* Inovasi chips row */
.i2-inovasi-row {
  display: flex; align-items: center; flex-wrap: wrap; gap: var(--sp-2);
  padding: var(--sp-5) var(--sp-6);
  background: var(--clr-off-white); border-radius: var(--radius-xl);
}
.i2-inovasi-label {
  font-size: 0.78rem; font-weight: 700; color: var(--clr-text-muted);
  text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap;
  margin-right: var(--sp-1);
}
.i2-inovasi-chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 0.78rem; font-weight: 600;
  color: #a06200; background: rgba(249,167,3,0.12);
  padding: 0.3rem 0.75rem; border-radius: 20px;
  text-decoration: none; transition: background 0.2s, color 0.2s;
}
.i2-inovasi-chip:hover { background: rgba(249,167,3,0.25); color: #7a4a00; }
.i2-inovasi-see-all {
  margin-left: auto; font-size: 0.78rem; font-weight: 700;
  color: var(--clr-blue); text-decoration: none;
  white-space: nowrap; padding-left: var(--sp-2);
}
.i2-inovasi-see-all:hover { text-decoration: underline; }

/* â”€â”€â”€ Â§ 4 Editorial News â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.i2-editorial {
  background: var(--clr-off-white);
  padding: 5rem 0;
}
.i2-editorial-grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: var(--sp-8);
  align-items: start;
}
/* Featured article */
.i2-featured {
  display: block; text-decoration: none; color: inherit;
  background: var(--clr-white);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: box-shadow 0.3s, transform 0.3s;
  margin-bottom: var(--sp-5);
}
.i2-featured:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.i2-featured-img-wrap { position: relative; overflow: hidden; }
.i2-featured-img {
  width: 100%; height: 340px; object-fit: cover; display: block;
  transition: transform 0.5s ease;
}
.i2-featured:hover .i2-featured-img { transform: scale(1.04); }
.i2-featured-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(0,0,0,0.35) 0%, transparent 60%);
  pointer-events: none;
}
.i2-featured-cat {
  position: absolute; bottom: var(--sp-4); left: var(--sp-5);
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.07em;
  background: var(--clr-blue); color: #fff;
  padding: 0.3rem 0.75rem; border-radius: 20px;
}
.i2-featured-body { padding: var(--sp-6); }
.i2-featured-date {
  display: flex; align-items: center; gap: 5px;
  font-size: var(--fs-xs); color: var(--clr-text-muted);
  margin-bottom: var(--sp-3);
}
.i2-featured-title {
  font-size: 1.3rem; font-weight: 800; line-height: 1.35;
  color: var(--clr-text-primary); margin-bottom: var(--sp-3);
}
.i2-featured-excerpt {
  font-size: var(--fs-sm); color: var(--clr-text-secondary);
  line-height: var(--lh-relaxed); margin-bottom: var(--sp-5);
}
.i2-featured-readmore {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--fs-sm); font-weight: 700; color: var(--clr-blue);
}
/* Mini berita list below featured */
.i2-berita-mini-list { display: flex; flex-direction: column; gap: var(--sp-3); }
.i2-berita-mini {
  display: flex; gap: var(--sp-4); align-items: flex-start;
  background: var(--clr-white); border-radius: var(--radius-lg);
  overflow: hidden; text-decoration: none; color: inherit;
  box-shadow: var(--shadow-sm); transition: box-shadow 0.2s, transform 0.2s;
}
.i2-berita-mini:hover { box-shadow: var(--shadow-md); transform: translateX(3px); }
.i2-berita-mini-img { width: 100px; height: 72px; object-fit: cover; flex-shrink: 0; }
.i2-berita-mini-body { padding: var(--sp-3) var(--sp-4) var(--sp-3) 0; }
.i2-berita-mini-date { font-size: 0.7rem; color: var(--clr-text-muted); margin-bottom: var(--sp-1); }
.i2-berita-mini-title { font-size: 0.875rem; font-weight: 600; color: var(--clr-text-primary); line-height: 1.4; }
/* Sidebar */
.i2-editorial-sidebar { display: flex; flex-direction: column; gap: var(--sp-5); }
.i2-sidebar-group {
  background: var(--clr-white); border-radius: var(--radius-xl);
  padding: var(--sp-5); box-shadow: var(--shadow-sm);
}
.i2-sidebar-label {
  display: flex; align-items: center; gap: 7px;
  font-size: 0.72rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--clr-blue);
  margin-bottom: var(--sp-4); padding-bottom: var(--sp-3);
  border-bottom: 2px solid var(--clr-blue-pale);
}
.i2-sidebar-item {
  display: flex; flex-direction: column;
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--clr-border);
  text-decoration: none; color: inherit;
  transition: color 0.2s;
}
.i2-sidebar-item:last-of-type { border-bottom: none; }
.i2-sidebar-item:hover .i2-sidebar-title { color: var(--clr-blue); }
.i2-sidebar-date { font-size: 0.68rem; color: var(--clr-text-muted); margin-bottom: 4px; }
.i2-sidebar-title { font-size: 0.875rem; font-weight: 600; color: var(--clr-text-primary); line-height: 1.4; }
.i2-sidebar-see-all {
  display: block; margin-top: var(--sp-3);
  font-size: 0.78rem; font-weight: 700; color: var(--clr-blue);
  text-decoration: none;
}
.i2-sidebar-see-all:hover { text-decoration: underline; }

/* â”€â”€â”€ Â§ 5 Layanan Cepat â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.i2-services {
  background: var(--clr-dark);
  padding: 5rem 0;
  position: relative; overflow: hidden;
}
.i2-services-glow {
  position: absolute; border-radius: 50%; pointer-events: none;
  filter: blur(60px); will-change: transform;
}
.i2-glow-a {
  width: 420px; height: 420px; top: 30%; left: -5%;
  background: radial-gradient(circle, rgba(6,122,193,0.16), transparent 70%);
}
.i2-glow-b {
  width: 380px; height: 380px; bottom: 10%; right: -5%;
  background: radial-gradient(circle, rgba(249,167,3,0.10), transparent 70%);
}
.i2-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.i2-service-card {
  display: flex; flex-direction: column;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-xl);
  padding: 1.75rem;
  text-decoration: none; color: #fff;
  transition: background 0.25s, border-color 0.25s, transform 0.25s;
}
.i2-service-card:hover {
  background: rgba(255,255,255,0.09);
  border-color: rgba(6,122,193,0.35);
  transform: translateY(-3px);
}
.i2-service-icon {
  width: 48px; height: 48px;
  background: rgba(6,122,193,0.2);
  border: 1px solid rgba(6,122,193,0.3);
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem; color: var(--clr-blue-light);
}
.i2-service-title { font-size: 1rem; font-weight: 800; color: #fff; margin-bottom: 0.5rem; }
.i2-service-desc  { font-size: 0.82rem; color: rgba(255,255,255,0.45); line-height: 1.65; flex: 1; margin-bottom: 1.25rem; }
.i2-service-arrow {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.72rem; font-weight: 700; color: var(--clr-gold);
  letter-spacing: 0.03em; transition: gap 0.2s;
}
.i2-service-card:hover .i2-service-arrow { gap: 0.65rem; }

/* â”€â”€â”€ Â§ 6 About & Contact â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.i2-about {
  background: var(--clr-white);
  padding: 5rem 0;
}
.i2-about-grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 4rem;
  align-items: start;
}
.i2-about-features {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5);
  margin-top: var(--sp-8);
}
.i2-about-feat {
  display: flex; align-items: flex-start; gap: var(--sp-3);
}
.i2-about-feat-icon {
  width: 38px; height: 38px; flex-shrink: 0;
  background: rgba(6,122,193,0.08); border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center; color: var(--clr-blue);
}
.i2-about-feat-title { font-size: 0.875rem; font-weight: 700; color: var(--clr-text-primary); margin-bottom: 3px; }
.i2-about-feat-desc  { font-size: 0.775rem; color: var(--clr-text-muted); line-height: 1.5; }
/* Contact card */
.i2-contact-card {
  background: var(--clr-off-white);
  border-radius: var(--radius-2xl);
  padding: var(--sp-7);
  box-shadow: var(--shadow-sm);
}
.i2-contact-header {
  display: flex; align-items: center; gap: var(--sp-2);
  font-size: 0.78rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--clr-blue);
  margin-bottom: var(--sp-5); padding-bottom: var(--sp-4);
  border-bottom: 2px solid var(--clr-blue-pale);
}

/* =========================================================
   INDEX 4 â€” Stacked Parallax Continuity Homepage
   Sections overlap as rounded cards; each background layer
   parallaxes independently, creating multi-depth feel.
   ========================================================= */

/* â”€â”€ Â§ 1 Hero â”€â”€ */
.i4-hero {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  background: var(--clr-dark);
}
.i4-parallax-bg {
  position: absolute; inset: 0;
  will-change: transform;
}
.i4-hero-content {
  height: 100vh;
  display: flex; align-items: center;
}
.i4-hero-layout {
  display: grid;
  grid-template-columns: 1fr 330px;
  gap: 3rem;
  align-items: center;
  padding: 7rem 0 4rem;
}
.i4-hero-text { max-width: 680px; }

/* Hero floating card â€” identical visual to i3 but i4- prefix */
.i4-hero-card {
  position: relative;
  background: rgba(255,255,255,0.07);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-2xl);
  padding: 2rem 1.75rem 1.75rem;
  color: #fff;
  box-shadow: 0 24px 64px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.12);
  will-change: transform;
}
.i4-hero-card-ring {
  position: absolute; inset: -18px;
  border-radius: calc(var(--radius-2xl) + 18px);
  border: 1px solid rgba(255,255,255,0.07);
  pointer-events: none;
}
.i4-hero-card-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-lg);
  background: rgba(6,122,193,0.25);
  border: 1px solid rgba(6,122,193,0.35);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-blue-light);
  margin-bottom: 1rem;
}
.i4-hero-card-num {
  font-size: clamp(2.8rem, 5vw, 4rem);
  font-weight: 900; line-height: 1;
  letter-spacing: -0.02em; color: #fff;
  margin-bottom: 0.25rem;
}
.i4-hero-card-sub {
  font-size: 0.78rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: rgba(255,255,255,0.5); margin-bottom: 1.25rem;
}
.i4-hero-card-sep { height: 1px; background: rgba(255,255,255,0.1); margin-bottom: 1.25rem; }
.i4-hero-card-pills { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 1.25rem; }
.i4-pill {
  display: inline-flex; align-items: center;
  padding: 0.3rem 0.75rem; border-radius: 999px;
  font-size: 0.7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
}
.i4-pill.blue { background: rgba(6,122,193,0.2); border: 1px solid rgba(6,122,193,0.35); color: var(--clr-blue-light); }
.i4-pill.gold { background: rgba(249,167,3,0.15); border: 1px solid rgba(249,167,3,0.3); color: var(--clr-gold-light); }
.i4-hero-card-cta {
  display: block; font-size: 0.78rem; font-weight: 700;
  color: var(--clr-gold-light); text-decoration: none;
  letter-spacing: 0.03em; transition: color 0.2s;
}
.i4-hero-card-cta:hover { color: #fff; }

/* Scroll cue */
.i4-scroll-cue {
  position: absolute; bottom: 2rem; left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  color: rgba(255,255,255,0.45); font-size: 0.7rem;
  font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  z-index: 10;
}
.i4-scroll-cue-line {
  width: 1px; height: 48px;
  background: linear-gradient(180deg, transparent 0%, rgba(255,255,255,0.5) 100%);
  animation: i4CuePulse 1.8s ease-in-out infinite;
}
@keyframes i4CuePulse {
  0%, 100% { opacity: 0.3; transform: scaleY(0.7); transform-origin: top; }
  50%       { opacity: 1;   transform: scaleY(1);   transform-origin: top; }
}

/* â”€â”€ Stacked section pattern â”€â”€
   Each .i4-section overlaps the previous by 3rem via negative margin-top.
   The rounded top corners + box-shadow reinforce the "card slides over" feel.
   .i4-section-bg is 120% tall and parallaxed by GSAP (fromTo yPercent -10â†’+10).
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.i4-section {
  position: relative;
  margin-top: -3rem;
  border-radius: 1.75rem 1.75rem 0 0;
  overflow: hidden;
  box-shadow: 0 -8px 40px rgba(0,0,0,0.10);
}
.i4-section-bg {
  position: absolute;
  inset: -12% 0;
  will-change: transform;
  z-index: 0;
}
.i4-section-inner {
  position: relative;
  z-index: 1;
  padding: var(--sp-16) 0;
}

/* Background colors — all light sections use clr-white so connectors look IDENTICAL across boundaries */
.i4-programs-bg  { background: var(--clr-white); }
.i4-inovasi-bg   { background: linear-gradient(160deg, #062c58 0%, #043870 50%, #062c58 100%); }
.i4-editorial-bg { background: var(--clr-white); }
.i4-services-bg  { background: linear-gradient(145deg, #053060 0%, #074282 55%, #053060 100%); }
.i4-about-bg     { background: var(--clr-white); }
.i4-cta-bg       { background: linear-gradient(135deg, var(--clr-dark) 0%, var(--clr-blue-deeper) 50%, var(--clr-dark) 100%); }

/* z-index stacking order â€” applies only to stacked .i4-section cards.
   The standalone search .i4-cta inside .i4-page-top must NOT take z-index here,
   otherwise it would cover the rounded top of the first stacked section below. */
.i4-section.i4-programs  { z-index: 2; }
.i4-section.i4-jadwal    { z-index: 3; }
.i4-section.i4-editorial { z-index: 4; }
.i4-section.i4-layanan   { z-index: 5; }
.i4-section.i4-about     { z-index: 6; }
.i4-section.i4-cta       { z-index: 7; }
.i4-section.i4-services  { z-index: 5; }
.i4-section.i4-inovasi   { z-index: 3; }

/* â”€â”€ Â§ 3 Programs â”€â”€ */
.i4-section-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: var(--sp-6); margin-bottom: var(--sp-10);
}
.i4-programs-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: var(--sp-8);
}
@media (max-width: 1100px) { .i4-programs-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .i4-programs-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .i4-programs-grid { grid-template-columns: 1fr; } }

.i4-program-card {
  display: flex; flex-direction: column;
  background: var(--clr-off-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  padding: 1.5rem;
  text-decoration: none; color: var(--clr-text-primary);
  transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s;
}
.i4-program-card:hover {
  border-color: var(--clr-blue);
  box-shadow: 0 8px 32px rgba(6,122,193,0.1);
  transform: translateY(-3px);
}
.i4-program-num {
  font-size: 2.4rem; font-weight: 900; line-height: 1;
  letter-spacing: -0.04em; color: var(--clr-border-dark);
  margin-bottom: 1rem;
}
.i4-program-name {
  font-size: 0.95rem; font-weight: 800;
  color: var(--clr-text-primary); line-height: 1.35;
  margin-bottom: 0.5rem; flex: 1;
}
.i4-program-desc {
  font-size: 0.78rem; color: var(--clr-text-muted);
  line-height: 1.6; margin-bottom: 1rem;
}
.i4-program-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 1rem; border-top: 1px solid var(--clr-border);
}
.i4-program-badge {
  display: inline-block;
  padding: 0.22rem 0.6rem; border-radius: 999px;
  font-size: 0.62rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.07em;
  background: var(--clr-blue-pale); color: var(--clr-blue);
}
.i4-program-arrow {
  display: flex; align-items: center; gap: 0.35rem;
  font-size: 0.72rem; font-weight: 700; color: var(--clr-blue);
  transition: gap 0.2s;
}
.i4-program-card:hover .i4-program-arrow { gap: 0.6rem; }

/* Inovasi row */
.i4-inovasi-row {
  display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem;
  padding: var(--sp-4) var(--sp-5);
  background: var(--clr-blue-glass);
  border: 1px solid var(--clr-blue-pale);
  border-radius: var(--radius-xl);
}
.i4-inovasi-label {
  font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--clr-blue); margin-right: 0.25rem;
}
.i4-inovasi-chip {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.3rem 0.75rem; border-radius: 999px;
  font-size: 0.72rem; font-weight: 600;
  background: rgba(6,122,193,0.08);
  border: 1px solid rgba(6,122,193,0.18);
  color: var(--clr-blue); text-decoration: none;
  transition: background 0.2s;
}
.i4-inovasi-chip:hover { background: rgba(6,122,193,0.16); }
.i4-inovasi-see-all {
  font-size: 0.72rem; font-weight: 700;
  color: var(--clr-blue); text-decoration: none;
  margin-left: auto;
}
.i4-inovasi-see-all:hover { text-decoration: underline; }

/* Programs parallax blobs */
.i4-blob-a {
  position: absolute; left: -8%; top: 10%;
  width: 500px; height: 500px; border-radius: 50%;
  background: radial-gradient(circle, rgba(6,122,193,0.07) 0%, transparent 70%);
  filter: blur(60px); pointer-events: none; will-change: transform;
}
.i4-blob-b {
  position: absolute; right: -6%; bottom: 5%;
  width: 400px; height: 400px; border-radius: 50%;
  background: radial-gradient(circle, rgba(249,167,3,0.06) 0%, transparent 70%);
  filter: blur(60px); pointer-events: none; will-change: transform;
}

/* â”€â”€ Â§ 4 Editorial â”€â”€ */
.i4-editorial-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--sp-4); margin-bottom: var(--sp-10);
}
.i4-editorial-grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 3rem; align-items: start;
}
@media (max-width: 900px) { .i4-editorial-grid { grid-template-columns: 1fr; } }

/* Feature card */
.i4-feature-card {
  display: block; text-decoration: none; color: var(--clr-text-primary);
  border-radius: var(--radius-2xl); overflow: hidden;
  border: 1px solid var(--clr-border);
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.25s, transform 0.25s;
}
.i4-feature-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.i4-feature-img-clip { position: relative; overflow: hidden; aspect-ratio: 16/9; }
.i4-feature-img { width: 100%; height: 100%; object-fit: cover; display: block; will-change: transform; }
.i4-feature-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(15,23,42,0.55) 100%);
}
.i4-feature-cat {
  position: absolute; top: 1rem; left: 1rem;
  display: inline-block; padding: 0.3rem 0.75rem; border-radius: 999px;
  font-size: 0.65rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.07em; background: var(--clr-blue); color: #fff;
}
.i4-feature-body { padding: 1.5rem; background: #fff; }
.i4-feature-date { display: flex; align-items: center; gap: 0.4rem; font-size: 0.72rem; color: var(--clr-text-muted); margin-bottom: 0.6rem; }
.i4-feature-title { font-size: 1.15rem; font-weight: 800; line-height: 1.4; color: var(--clr-text-primary); margin: 0 0 0.75rem; }
.i4-feature-excerpt { font-size: 0.85rem; color: var(--clr-text-secondary); line-height: 1.7; margin: 0 0 1rem; }
.i4-feature-read {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.78rem; font-weight: 700; color: var(--clr-blue); transition: gap 0.2s;
}
.i4-feature-card:hover .i4-feature-read { gap: 0.7rem; }

/* Mini list */
.i4-mini-list { display: flex; flex-direction: column; margin-top: var(--sp-5); border: 1px solid var(--clr-border); border-radius: var(--radius-xl); overflow: hidden; }
.i4-mini-item { display: flex; align-items: center; gap: 1rem; padding: 0.9rem 1rem; text-decoration: none; color: var(--clr-text-primary); background: #fff; border-bottom: 1px solid var(--clr-border); transition: background 0.2s; }
.i4-mini-item:last-child { border-bottom: none; }
.i4-mini-item:hover { background: var(--clr-off-white); }
.i4-mini-thumb { width: 72px; height: 50px; object-fit: cover; border-radius: var(--radius-sm); flex-shrink: 0; }
.i4-mini-body { flex: 1; min-width: 0; }
.i4-mini-date { font-size: 0.68rem; color: var(--clr-text-muted); margin-bottom: 0.25rem; }
.i4-mini-title { font-size: 0.82rem; font-weight: 700; line-height: 1.4; color: var(--clr-text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Sidebar */
.i4-sidebar-box { border: 1px solid var(--clr-border); border-radius: var(--radius-xl); overflow: hidden; background: #fff; }
.i4-sidebar-head { display: flex; align-items: center; gap: 0.5rem; padding: 1rem 1.25rem; font-size: 0.78rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em; color: var(--clr-blue); background: var(--clr-off-white); border-bottom: 1px solid var(--clr-border); }
.i4-sidebar-item { display: block; padding: 0.85rem 1.25rem; text-decoration: none; border-bottom: 1px solid var(--clr-border); transition: background 0.15s; }
.i4-sidebar-item:last-of-type { border-bottom: none; }
.i4-sidebar-item:hover { background: var(--clr-off-white); }
.i4-sidebar-date { font-size: 0.68rem; color: var(--clr-text-muted); margin-bottom: 0.2rem; }
.i4-sidebar-title { font-size: 0.825rem; font-weight: 700; color: var(--clr-text-primary); line-height: 1.45; }
.i4-sidebar-more { display: block; padding: 0.75rem 1.25rem; font-size: 0.72rem; font-weight: 700; color: var(--clr-blue); text-decoration: none; background: var(--clr-off-white); border-top: 1px solid var(--clr-border); transition: background 0.15s; }
.i4-sidebar-more:hover { background: var(--clr-blue-pale); }

/* â”€â”€ Â§ 5 Services â”€â”€ */
.i4-services-glow-l {
  position: absolute; left: -5%; top: 25%;
  width: 420px; height: 420px; border-radius: 50%;
  background: radial-gradient(circle, rgba(6,122,193,0.16) 0%, transparent 70%);
  filter: blur(60px); pointer-events: none; will-change: transform;
}
.i4-services-glow-r {
  position: absolute; right: -5%; bottom: 15%;
  width: 380px; height: 380px; border-radius: 50%;
  background: radial-gradient(circle, rgba(249,167,3,0.10) 0%, transparent 70%);
  filter: blur(60px); pointer-events: none; will-change: transform;
}
.i4-services-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem;
}
@media (max-width: 900px) { .i4-services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .i4-services-grid { grid-template-columns: 1fr; } }

.i4-service-card {
  display: flex; flex-direction: column;
  padding: 1.75rem; border-radius: var(--radius-xl);
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08);
  text-decoration: none; color: #fff;
  transition: background 0.25s, border-color 0.25s, transform 0.25s;
}
.i4-service-card:hover { background: rgba(255,255,255,0.09); border-color: rgba(6,122,193,0.35); transform: translateY(-3px); }
.i4-service-icon { width: 48px; height: 48px; border-radius: var(--radius-md); background: rgba(6,122,193,0.2); border: 1px solid rgba(6,122,193,0.3); display: flex; align-items: center; justify-content: center; color: var(--clr-blue-light); margin-bottom: 1.25rem; }
.i4-service-title { font-size: 1rem; font-weight: 800; color: #fff; margin-bottom: 0.5rem; }
.i4-service-desc  { font-size: 0.82rem; color: rgba(255,255,255,0.45); line-height: 1.65; flex: 1; margin-bottom: 1.25rem; }
.i4-service-arrow { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.72rem; font-weight: 700; color: var(--clr-gold); letter-spacing: 0.03em; transition: gap 0.2s; }
.i4-service-card:hover .i4-service-arrow { gap: 0.65rem; }

/* â”€â”€ Â§ 6 About â”€â”€ */
.i4-about-grid {
  display: grid; grid-template-columns: 3fr 2fr; gap: 4rem; align-items: start;
}
@media (max-width: 900px) { .i4-about-grid { grid-template-columns: 1fr; gap: 2.5rem; } }

.i4-about-features { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); margin-top: var(--sp-8); }
@media (max-width: 540px) { .i4-about-features { grid-template-columns: 1fr; } }

.i4-about-feat { display: flex; align-items: flex-start; gap: var(--sp-3); }
.i4-about-feat-icon { width: 38px; height: 38px; flex-shrink: 0; background: rgba(6,122,193,0.08); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; color: var(--clr-blue); }
.i4-about-feat-title { font-size: 0.875rem; font-weight: 700; color: var(--clr-text-primary); margin-bottom: 3px; }
.i4-about-feat-desc  { font-size: 0.775rem; color: var(--clr-text-muted); line-height: 1.5; }

/* Contact card */
.i4-contact-card { background: var(--clr-off-white); border-radius: var(--radius-2xl); padding: 1.75rem 2rem; box-shadow: var(--shadow-sm); }
.i4-contact-header { display: flex; align-items: center; gap: var(--sp-2); font-size: 0.78rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em; color: var(--clr-blue); margin-bottom: var(--sp-6); padding-bottom: var(--sp-4); border-bottom: 2px solid var(--clr-blue-pale); }
.i4-contact-item { display: flex; align-items: flex-start; gap: var(--sp-3); margin-bottom: var(--sp-5); padding: 0.15rem 0; }
.i4-contact-icon { width: 32px; height: 32px; flex-shrink: 0; background: rgba(6,122,193,0.08); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; color: var(--clr-blue); margin-top: 2px; }
.i4-contact-key { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--clr-text-muted); margin-bottom: 2px; }
.i4-contact-val { font-size: 0.85rem; color: var(--clr-text-primary); line-height: 1.5; }
.i4-contact-map-btn { display: flex; align-items: center; gap: 0.5rem; margin-top: var(--sp-5); padding: 0.65rem 1rem; border-radius: var(--radius-md); background: var(--clr-blue); color: #fff; font-size: 0.78rem; font-weight: 700; text-decoration: none; transition: background 0.2s; }
.i4-contact-map-btn:hover { background: var(--clr-blue-dark); }

/* â”€â”€ Â§ 7 CTA â”€â”€ */
.i4-cta-orb-l { position: absolute; left: -8%; top: -20%; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle, rgba(6,122,193,0.22) 0%, transparent 65%); filter: blur(70px); pointer-events: none; will-change: transform; }
.i4-cta-orb-r { position: absolute; right: -8%; bottom: -20%; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle, rgba(249,167,3,0.15) 0%, transparent 65%); filter: blur(70px); pointer-events: none; will-change: transform; }
.i4-cta-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px); background-size: 48px 48px; pointer-events: none; }
.i4-cta-inner { display: flex; justify-content: space-between; align-items: center; gap: 3rem; }

/* â”€â”€ Â§ Inovasi section â”€â”€ */
.i4-inovasi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-5);
}
@media (max-width: 1200px) { .i4-inovasi-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 900px)  { .i4-inovasi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .i4-inovasi-grid { grid-template-columns: 1fr; } }

.i4-inovasi-card {
  position: relative;
  display: flex; flex-direction: column;
  background: linear-gradient(140deg, rgba(6,100,200,0.22) 0%, rgba(3,44,92,0.75) 100%);
  border: 1px solid rgba(6,122,193,0.22);
  border-radius: var(--radius-xl);
  padding: var(--sp-6) var(--sp-5);
  overflow: hidden;
  text-decoration: none; color: #fff;
  transition: transform 0.28s, box-shadow 0.28s, border-color 0.28s;
}
.i4-inovasi-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 20px 48px rgba(6,122,193,0.22);
  border-color: rgba(6,122,193,0.5);
}
/* Decorative glow orb top-right */
.i4-inovasi-card::before {
  content: '';
  position: absolute; top: -24px; right: -24px;
  width: 90px; height: 90px; border-radius: 50%;
  background: radial-gradient(circle, rgba(249,167,3,0.12) 0%, transparent 70%);
  pointer-events: none;
}
.i4-inovasi-card-star { display: none; }
.i4-inovasi-card-icon {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(249,167,3,0.12);
  border: 1px solid rgba(249,167,3,0.28);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-gold); margin-bottom: 0.75rem; flex-shrink: 0;
  font-size: 0.85rem; font-weight: 900; letter-spacing: -0.02em; line-height: 1;
}
.i4-inovasi-card-eyebrow {
  font-size: 0.6rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--clr-gold); margin-bottom: 0.3rem;
}
.i4-inovasi-card-name {
  font-size: 0.9rem; font-weight: 700;
  line-height: 1.35; color: #fff;
  margin-bottom: 0.4rem; flex: 1;
}
.i4-inovasi-card-desc {
  font-size: 0.78rem; color: rgba(255,255,255,0.45);
  line-height: 1.6; margin-bottom: 0.75rem;
}
.i4-inovasi-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 0.75rem;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.i4-inovasi-badge {
  display: inline-block;
  padding: 0.22rem 0.6rem; border-radius: 999px;
  background: rgba(249,167,3,0.12); border: 1px solid rgba(249,167,3,0.25);
  color: var(--clr-gold); font-size: 0.62rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.07em;
}
.i4-inovasi-card-arrow {
  display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.72rem; font-weight: 700; color: var(--clr-gold-light);
  transition: gap 0.2s;
}
.i4-inovasi-card:hover .i4-inovasi-card-arrow { gap: 0.65rem; }

/* â”€â”€ Section top ornament (inline static connector dots) â”€â”€ */
.i4-sec-ornament {
  display: flex; justify-content: center; align-items: center;
  height: 52px; position: relative; margin-bottom: 1.5rem;
}
/* Programs & Search: hide the in-flow ornament â€” replaced by a real .i4-connector
   placed BEFORE each section, so the dots straddle the section seam exactly like
   the Inovasi connector. */
.i4-cta .i4-sec-ornament,
.i4-programs > .i4-section-inner > .i4-sec-ornament {
  display: none;
}
.i4-sec-ornament > .i4-conn-center {
  position: relative; top: auto; left: auto; transform: none;
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
}
.i4-sec-ornament > .i4-conn-particle {
  position: absolute; top: 50%; transform: translateY(-50%);
}
.i4-sec-ornament > .i4-conn-p1 { left: calc(50% - 56px); }
.i4-sec-ornament > .i4-conn-p2 { right: calc(50% - 56px); left: auto; }
.i4-sec-ornament > .i4-conn-p3 { left: calc(50% - 110px); }
.i4-sec-ornament > .i4-conn-p4 { right: calc(50% - 110px); left: auto; }

/* â”€â”€ Section Connectors â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   Height-0 divs between stacked sections; children use
   position:absolute and overflow:visible to straddle the
   boundary. z-index:50 sits above all .i4-section layers.
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.i4-connector {
  position: relative;
  height: 0;
  overflow: visible;
  z-index: 50;
  pointer-events: none;
}
.i4-conn-center {
  position: absolute;
  top: -26px;
  left: 50%;
  transform: translateX(-50%);
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
}
.i4-conn-ring {
  position: absolute; border-radius: 50%; border-style: solid;
}
.i4-conn-r1 {
  inset: 0; border-width: 2px;
  border-color: rgba(6,122,193,0.5);
  animation: i4ConnSpin 11s linear infinite;
}
.i4-conn-r2 {
  inset: 10px; border-width: 1.5px;
  border-color: rgba(249,167,3,0.42);
  animation: i4ConnSpin 7s linear infinite reverse;
}
.i4-conn-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--clr-blue);
  box-shadow: 0 0 12px rgba(6,122,193,0.7);
  animation: i4ConnPulse 2.4s ease-in-out infinite;
  z-index: 1;
}
.i4-conn-particle {
  position: absolute; top: -22px;
  width: 7px; height: 7px; border-radius: 50%;
}
.i4-conn-p1 { left: calc(50% - 72px); background: rgba(6,122,193,0.55); animation: i4ConnFloat 3.6s ease-in-out infinite; }
.i4-conn-p2 { right: calc(50% - 72px); background: rgba(249,167,3,0.55); animation: i4ConnFloat 3.6s ease-in-out infinite 1.8s; }
/* Extra far particles for wider screens */
.i4-conn-p3 { left: calc(50% - 140px); width: 5px; height: 5px; background: rgba(6,122,193,0.3); animation: i4ConnFloat 5s ease-in-out infinite 0.9s; }
.i4-conn-p4 { right: calc(50% - 140px); width: 5px; height: 5px; background: rgba(249,167,3,0.3); animation: i4ConnFloat 5s ease-in-out infinite 2.7s; }

@keyframes i4ConnSpin  { to { transform: rotate(360deg); } }
@keyframes i4ConnPulse {
  0%, 100% { transform: scale(1);   opacity: 0.7; }
  50%       { transform: scale(1.6); opacity: 1;   }
}
@keyframes i4ConnFloat {
  0%, 100% { transform: translateY(0);   opacity: 0.4; }
  50%       { transform: translateY(-9px); opacity: 1;   }
}

/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 1024px) {
  .i4-section-header { flex-direction: column; }
  /* Tablet & mobile: hide floating stat card, give text full width */
  .i4-hero-layout { grid-template-columns: 1fr; }
  .i4-hero-card   { display: none; }
  .i4-hero-text   { max-width: none; }
}
@media (max-width: 768px) {
  .i4-hero-layout { padding: 6rem 0 5rem; }
  .i4-cta-inner   { flex-direction: column; align-items: flex-start; }
  .i4-editorial-header { flex-direction: column; align-items: flex-start; }
  .i4-section { margin-top: -1.5rem; border-radius: 1rem 1rem 0 0; }
  .i4-connector { display: none; }
}

/* =========================================================
   INDEX 3 â€” Scrollytelling / Parallax Continuity Homepage
   All classes prefixed with i3-
   ========================================================= */

/* â”€â”€ Â§ 1 Hero â”€â”€ */
.i3-hero {
  position: relative;
  height: 100vh; min-height: 600px;
  overflow: hidden;
  background: var(--clr-dark);
}
.i3-parallax-bg {
  position: absolute; inset: 0;
  will-change: transform;
}
.i3-hero-content {
  height: 100%;
  display: flex; align-items: center;
}
.i3-hero-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 3rem;
  align-items: center;
  padding: 7rem 0 4rem;
}
.i3-hero-text { max-width: 680px; }

/* Floating glassmorphism card */
.i3-hero-card {
  position: relative;
  background: rgba(255,255,255,0.07);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--radius-2xl);
  padding: 2rem 1.75rem 1.75rem;
  color: #fff;
  box-shadow: 0 24px 64px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.12);
  will-change: transform;
}
.i3-hero-card-ring {
  position: absolute;
  inset: -18px;
  border-radius: calc(var(--radius-2xl) + 18px);
  border: 1px solid rgba(255,255,255,0.07);
  pointer-events: none;
}
.i3-hero-card-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-lg);
  background: rgba(6,122,193,0.25);
  border: 1px solid rgba(6,122,193,0.35);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-blue-light);
  margin-bottom: 1rem;
}
.i3-hero-card-num {
  font-size: clamp(2.8rem, 5vw, 4rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.02em;
  color: #fff;
  margin-bottom: 0.25rem;
}
.i3-hero-card-sub {
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.5);
  margin-bottom: 1.25rem;
}
.i3-hero-card-sep {
  height: 1px;
  background: rgba(255,255,255,0.1);
  margin-bottom: 1.25rem;
}
.i3-hero-card-pills {
  display: flex; gap: 0.5rem; flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.i3-pill {
  display: inline-flex; align-items: center;
  padding: 0.3rem 0.75rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.i3-pill.blue {
  background: rgba(6,122,193,0.2);
  border: 1px solid rgba(6,122,193,0.35);
  color: var(--clr-blue-light);
}
.i3-pill.gold {
  background: rgba(249,167,3,0.15);
  border: 1px solid rgba(249,167,3,0.3);
  color: var(--clr-gold-light);
}
.i3-hero-card-cta {
  display: block;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--clr-gold-light);
  text-decoration: none;
  letter-spacing: 0.03em;
  transition: color 0.2s;
}
.i3-hero-card-cta:hover { color: #fff; }

/* Scroll cue */
.i3-scroll-cue {
  position: absolute;
  bottom: 2rem; left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center;
  gap: 0.5rem;
  color: rgba(255,255,255,0.45);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  z-index: 10;
}
.i3-scroll-cue-line {
  width: 1px; height: 48px;
  background: linear-gradient(180deg, transparent 0%, rgba(255,255,255,0.5) 100%);
  animation: i3CuePulse 1.8s ease-in-out infinite;
}
@keyframes i3CuePulse {
  0%, 100% { opacity: 0.3; transform: scaleY(0.7); transform-origin: top; }
  50%       { opacity: 1;   transform: scaleY(1);   transform-origin: top; }
}

/* â”€â”€ Â§ 3 Dalam Angka (Scrollytelling pinned) â”€â”€ */
.i3-angka {
  position: relative;
  min-height: 100vh;
  background: var(--clr-dark);
  display: flex; align-items: center;
  overflow: hidden;
}
.i3-angka-grid-bg {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 64px 64px;
  pointer-events: none;
}
.i3-angka-glow-l {
  position: absolute; left: -10%; top: 20%;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(6,122,193,0.18) 0%, transparent 70%);
  filter: blur(60px);
  pointer-events: none;
}
.i3-angka-glow-r {
  position: absolute; right: -10%; bottom: 10%;
  width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(249,167,3,0.12) 0%, transparent 70%);
  filter: blur(60px);
  pointer-events: none;
}
.i3-angka-inner {
  position: relative; z-index: 2;
  width: 100%;
  padding: var(--sp-16) 0;
}
.i3-angka-header {
  text-align: center;
  margin-bottom: var(--sp-14);
}
.i3-angka-eyebrow {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--clr-gold);
  margin-bottom: var(--sp-3);
}
.i3-angka-title {
  font-size: clamp(2rem, 4vw, 3.25rem);
  font-weight: 900;
  line-height: 1.15;
  color: #fff;
  margin: 0;
}
.i3-angka-title em {
  font-style: normal;
  background: linear-gradient(90deg, var(--clr-blue-light), var(--clr-gold));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.i3-angka-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  margin-bottom: var(--sp-10);
}
@media (max-width: 900px) {
  .i3-angka-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .i3-angka-grid { grid-template-columns: 1fr; }
}
.i3-angka-item {
  text-align: center;
  padding: 2rem 1rem;
  border-radius: var(--radius-xl);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
}
.i3-angka-num {
  position: relative;
  display: inline-flex; align-items: flex-start;
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--clr-blue-light);
  margin-bottom: 0.75rem;
}
.i3-angka-sup {
  font-size: 0.45em;
  font-weight: 800;
  margin-top: 0.3em;
  color: inherit;
}
.i3-angka-label {
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 0.4rem;
}
.i3-angka-caption {
  font-size: 0.775rem;
  color: rgba(255,255,255,0.4);
  line-height: 1.5;
}
.i3-counter { display: inline; }
.i3-angka-progress-wrap {
  max-width: 500px; margin: 0 auto;
  height: 3px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
}
.i3-angka-progress-bar {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--clr-blue), var(--clr-gold));
  border-radius: 2px;
  transition: width 0.05s linear;
}

/* â”€â”€ Â§ 4 Horizontal Scroll â”€â”€ */
.i3-hscroll-wrapper {
  position: relative;
  overflow: hidden;
  background: var(--clr-off-white);
}
.i3-hscroll-progress-track {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--clr-border);
  z-index: 20;
}
.i3-hscroll-progress-fill {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--clr-blue), var(--clr-gold));
  transition: width 0.05s linear;
}
.i3-hscroll-viewport {
  width: 100%;
  height: 100vh;
  overflow: hidden;
}
.i3-hscroll-track {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  height: 100%;
  will-change: transform;
}

/* Lead panel */
.i3-hscroll-lead {
  flex-shrink: 0;
  width: 420px;
  height: 100%;
  display: flex; align-items: center;
  background: linear-gradient(135deg, var(--clr-dark) 0%, var(--clr-blue-deeper) 100%);
  padding: 0 3rem;
}
.i3-hscroll-lead-inner { width: 100%; }
.i3-hscroll-lead-title {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 900;
  line-height: 1.15;
  color: #fff;
  margin: 0.75rem 0 1rem;
}
.i3-hscroll-lead-desc {
  font-size: 0.9rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.7;
  margin-bottom: 2rem;
}
.i3-hscroll-hint {
  display: flex; align-items: center; gap: 0.75rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--clr-gold);
}
.i3-hscroll-hint-arrow {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(249,167,3,0.15);
  border: 1px solid rgba(249,167,3,0.3);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-gold);
}

/* Program cards */
.i3-hscroll-card {
  flex-shrink: 0;
  width: 300px;
  height: 100%;
  display: flex; flex-direction: column; justify-content: space-between;
  background: #fff;
  border-right: 1px solid var(--clr-border);
  padding: 2.5rem 1.75rem;
  text-decoration: none;
  color: var(--clr-text-primary);
  transition: background 0.25s;
}
.i3-hscroll-card:hover { background: var(--clr-off-white); }
.i3-hscroll-card-num {
  font-size: 3.5rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--clr-border-dark);
  margin-bottom: 1.5rem;
}
.i3-hscroll-card-body { flex: 1; }
.i3-hscroll-card-name {
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.35;
  color: var(--clr-text-primary);
  margin-bottom: 0.75rem;
}
.i3-hscroll-card-desc {
  font-size: 0.82rem;
  color: var(--clr-text-muted);
  line-height: 1.65;
}
.i3-hscroll-card-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 1.25rem;
  border-top: 1px solid var(--clr-border);
  margin-top: 1.5rem;
}
.i3-hscroll-badge {
  display: inline-block;
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  background: var(--clr-blue-pale);
  color: var(--clr-blue);
}
.i3-hscroll-link {
  display: flex; align-items: center; gap: 0.35rem;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--clr-blue);
  transition: gap 0.2s;
}
.i3-hscroll-card:hover .i3-hscroll-link { gap: 0.6rem; }

/* CTA panel at end of horizontal scroll */
.i3-hscroll-cta-panel {
  flex-shrink: 0;
  width: 380px;
  height: 100%;
  position: relative;
  display: flex; align-items: center;
  overflow: hidden;
}
.i3-hscroll-cta-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--clr-blue-dark) 0%, var(--clr-dark) 100%);
}
.i3-hscroll-cta-content {
  position: relative; z-index: 2;
  padding: 3rem;
  color: #fff;
}
.i3-hscroll-cta-icon {
  width: 52px; height: 52px;
  border-radius: var(--radius-lg);
  background: rgba(249,167,3,0.15);
  border: 1px solid rgba(249,167,3,0.25);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-gold);
  margin-bottom: 1.5rem;
}
.i3-hscroll-cta-title {
  font-size: 1.6rem;
  font-weight: 900;
  line-height: 1.25;
  margin: 0 0 0.75rem;
  color: #fff;
}
.i3-hscroll-cta-desc {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.65;
}
.i3-hscroll-cta-alt {
  display: inline-block;
  margin-top: 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255,255,255,0.45);
  text-decoration: none;
  transition: color 0.2s;
}
.i3-hscroll-cta-alt:hover { color: #fff; }

/* Mobile: disable horizontal scroll layout */
@media (max-width: 768px) {
  .i3-hscroll-viewport { height: auto; overflow: visible; }
  .i3-hscroll-track    { flex-direction: column; }
  .i3-hscroll-lead, .i3-hscroll-card, .i3-hscroll-cta-panel {
    width: 100%; height: auto;
  }
  .i3-hscroll-lead     { padding: 2.5rem var(--sp-5); }
  .i3-hscroll-cta-content { padding: 2rem var(--sp-5); }
  .i3-hscroll-hint     { display: none; }
}

/* â”€â”€ Â§ 5 Editorial / Parallax Continuity â”€â”€ */
.i3-editorial {
  padding: var(--sp-16) 0;
  background: var(--clr-white);
}
.i3-editorial-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-10);
}
.i3-editorial-grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 3rem;
  align-items: start;
}
@media (max-width: 900px) {
  .i3-editorial-grid { grid-template-columns: 1fr; }
}

/* Featured card */
.i3-feature-card {
  display: block;
  text-decoration: none;
  color: var(--clr-text-primary);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  border: 1px solid var(--clr-border);
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.25s, transform 0.25s;
}
.i3-feature-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}
.i3-feature-img-clip {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
}
.i3-feature-img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  will-change: transform;
}
.i3-feature-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(15,23,42,0.55) 100%);
}
.i3-feature-cat {
  position: absolute;
  top: 1rem; left: 1rem;
  display: inline-block;
  padding: 0.3rem 0.75rem;
  border-radius: 999px;
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  background: var(--clr-blue);
  color: #fff;
}
.i3-feature-body {
  padding: 1.5rem;
  background: #fff;
}
.i3-feature-date {
  display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.72rem;
  color: var(--clr-text-muted);
  margin-bottom: 0.6rem;
}
.i3-feature-title {
  font-size: 1.15rem;
  font-weight: 800;
  line-height: 1.4;
  color: var(--clr-text-primary);
  margin: 0 0 0.75rem;
}
.i3-feature-excerpt {
  font-size: 0.85rem;
  color: var(--clr-text-secondary);
  line-height: 1.7;
  margin: 0 0 1rem;
}
.i3-feature-read {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--clr-blue);
  transition: gap 0.2s;
}
.i3-feature-card:hover .i3-feature-read { gap: 0.7rem; }

/* Mini berita list */
.i3-mini-list {
  display: flex; flex-direction: column;
  gap: 0;
  margin-top: var(--sp-5);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.i3-mini-item {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.9rem 1rem;
  text-decoration: none;
  color: var(--clr-text-primary);
  background: #fff;
  border-bottom: 1px solid var(--clr-border);
  transition: background 0.2s;
}
.i3-mini-item:last-child { border-bottom: none; }
.i3-mini-item:hover { background: var(--clr-off-white); }
.i3-mini-thumb {
  width: 72px; height: 50px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.i3-mini-body { flex: 1; min-width: 0; }
.i3-mini-date {
  font-size: 0.68rem;
  color: var(--clr-text-muted);
  margin-bottom: 0.25rem;
}
.i3-mini-title {
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.4;
  color: var(--clr-text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Sidebar boxes */
.i3-sidebar-box {
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: #fff;
}
.i3-sidebar-head {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 1rem 1.25rem;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--clr-blue);
  background: var(--clr-off-white);
  border-bottom: 1px solid var(--clr-border);
}
.i3-sidebar-item {
  display: block;
  padding: 0.85rem 1.25rem;
  text-decoration: none;
  border-bottom: 1px solid var(--clr-border);
  transition: background 0.15s;
}
.i3-sidebar-item:last-of-type { border-bottom: none; }
.i3-sidebar-item:hover { background: var(--clr-off-white); }
.i3-sidebar-date {
  font-size: 0.68rem;
  color: var(--clr-text-muted);
  margin-bottom: 0.2rem;
}
.i3-sidebar-title {
  font-size: 0.825rem;
  font-weight: 700;
  color: var(--clr-text-primary);
  line-height: 1.45;
}
.i3-sidebar-more {
  display: block;
  padding: 0.75rem 1.25rem;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--clr-blue);
  text-decoration: none;
  background: var(--clr-off-white);
  border-top: 1px solid var(--clr-border);
  transition: background 0.15s;
}
.i3-sidebar-more:hover { background: var(--clr-blue-pale); }

/* â”€â”€ Â§ 6 Services â”€â”€ */
.i3-services {
  position: relative;
  background: var(--clr-dark);
  padding: var(--sp-16) 0;
  overflow: hidden;
}
.i3-services-glow-l {
  position: absolute; left: -5%; top: 30%;
  width: 420px; height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(6,122,193,0.16) 0%, transparent 70%);
  filter: blur(60px);
  pointer-events: none;
}
.i3-services-glow-r {
  position: absolute; right: -5%; bottom: 10%;
  width: 380px; height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(249,167,3,0.1) 0%, transparent 70%);
  filter: blur(60px);
  pointer-events: none;
}
.i3-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
@media (max-width: 900px) {
  .i3-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .i3-services-grid { grid-template-columns: 1fr; }
}
.i3-service-card {
  display: flex; flex-direction: column;
  padding: 1.75rem;
  border-radius: var(--radius-xl);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  text-decoration: none;
  color: #fff;
  transition: background 0.25s, border-color 0.25s, transform 0.25s;
}
.i3-service-card:hover {
  background: rgba(255,255,255,0.09);
  border-color: rgba(6,122,193,0.35);
  transform: translateY(-3px);
}
.i3-service-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  background: rgba(6,122,193,0.2);
  border: 1px solid rgba(6,122,193,0.3);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-blue-light);
  margin-bottom: 1.25rem;
}
.i3-service-title {
  font-size: 1rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: 0.5rem;
}
.i3-service-desc {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.45);
  line-height: 1.65;
  flex: 1;
  margin-bottom: 1.25rem;
}
.i3-service-arrow {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--clr-gold);
  letter-spacing: 0.03em;
  transition: gap 0.2s;
}
.i3-service-card:hover .i3-service-arrow { gap: 0.65rem; }

/* â”€â”€ Â§ 7 CTA â”€â”€ */
.i3-cta {
  position: relative;
  background: linear-gradient(135deg, var(--clr-dark) 0%, var(--clr-blue-deeper) 50%, var(--clr-dark) 100%);
  padding: var(--sp-20) 0;
  overflow: hidden;
}
.i3-cta-orb-l {
  position: absolute; left: -8%; top: -20%;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(6,122,193,0.22) 0%, transparent 65%);
  filter: blur(70px);
  pointer-events: none;
  will-change: transform;
}
.i3-cta-orb-r {
  position: absolute; right: -8%; bottom: -20%;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(249,167,3,0.15) 0%, transparent 65%);
  filter: blur(70px);
  pointer-events: none;
  will-change: transform;
}
.i3-cta-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
}
.i3-cta-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 3rem;
}
@media (max-width: 768px) {
  .i3-cta-inner {
    flex-direction: column;
    align-items: flex-start;
  }
  .i3-hero-layout {
    grid-template-columns: 1fr;
    padding: 6rem 0 3rem;
  }
  .i3-hero-card { display: none; }
  .i3-editorial-header {
    flex-direction: column;
    align-items: flex-start;
  }
}
.i2-contact-item {
  display: flex; align-items: flex-start; gap: var(--sp-4);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--clr-border);
}
.i2-contact-item:last-of-type { border-bottom: none; }
.i2-contact-icon {
  width: 38px; height: 38px; flex-shrink: 0;
  background: rgba(6,122,193,0.08); border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center; color: var(--clr-blue);
}
.i2-contact-key { font-size: 0.7rem; color: var(--clr-text-muted); font-weight: 600; margin-bottom: 3px; }
.i2-contact-val { font-size: 0.875rem; color: var(--clr-text-primary); font-weight: 600; line-height: 1.4; }
.i2-contact-map-btn {
  display: flex; align-items: center; justify-content: center; gap: var(--sp-2);
  width: 100%; margin-top: var(--sp-5);
  background: var(--clr-blue); color: #fff;
  font-size: 0.825rem; font-weight: 700;
  padding: var(--sp-3); border-radius: var(--radius-lg);
  text-decoration: none; transition: background 0.2s;
}
.i2-contact-map-btn:hover { background: var(--clr-blue-dark); color: #fff; }
.i2-socmed-row {
  display: flex; gap: var(--sp-2); flex-wrap: wrap; margin-top: var(--sp-4);
}
.i2-socmed-btn {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  background: var(--clr-off-white); border: 1px solid var(--clr-border);
  border-radius: var(--radius-md); color: var(--clr-text-muted);
  text-decoration: none; transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.i2-socmed-btn:hover { background: var(--clr-blue); color: #fff; border-color: var(--clr-blue); }

/* â”€â”€â”€ Â§ 7 CTA Banner â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.i2-cta {
  background: var(--grad-hero);
  padding: 5rem 0;
  position: relative; overflow: hidden;
}
.i2-cta-grid-overlay {
  position: absolute; inset: 0; pointer-events: none;
  background-image: linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 48px 48px;
}
.i2-cta-orb {
  position: absolute; right: -80px; top: -80px;
  width: 380px; height: 380px;
  background: rgba(249,167,3,0.12); border-radius: 50%;
  pointer-events: none; filter: blur(60px);
}
.i2-cta-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 3rem; flex-wrap: wrap;
}

/* â”€â”€â”€ Responsive adjustments â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 1200px) {
  .i2-programs-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1024px) {
  .i2-hero-card { display: none; }
  .i2-programs-grid { grid-template-columns: repeat(2, 1fr); }
  .i2-editorial-grid { grid-template-columns: 1fr; }
  .i2-editorial-sidebar { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
  .i2-about-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .i2-services-grid { grid-template-columns: repeat(2, 1fr); }
  .i2-cta-inner { flex-direction: column; text-align: center; align-items: center; }
  .i2-section-header { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 768px) {
  .i2-programs-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
  .i2-editorial-sidebar { grid-template-columns: 1fr; }
  .i2-services-grid { grid-template-columns: 1fr 1fr; }
  .i2-about-features { grid-template-columns: 1fr; }
  .i2-featured-img { height: 240px; }
  .i2-scroll-indicator { display: none; }
}
@media (max-width: 480px) {
  .i2-programs-grid { grid-template-columns: 1fr; }
  .i2-services-grid { grid-template-columns: 1fr; }
  .i2-hero-content { padding-bottom: var(--sp-16); }
  .i2-contact-card { padding: var(--sp-5); }
}

/* =========================================================
   INDEX â€” Inovasi section blobs + utility additions
   ========================================================= */

/* Parallax blobs for the Inovasi section (dark bg) */
.i4-inovasi-blob-l {
  position: absolute; left: -8%; top: 10%;
  width: 420px; height: 420px; border-radius: 50%;
  background: radial-gradient(circle, rgba(6,122,193,0.18) 0%, transparent 65%);
  filter: blur(70px);
  pointer-events: none; will-change: transform;
}
.i4-inovasi-blob-r {
  position: absolute; right: -6%; bottom: 5%;
  width: 380px; height: 380px; border-radius: 50%;
  background: radial-gradient(circle, rgba(249,167,3,0.12) 0%, transparent 65%);
  filter: blur(70px);
  pointer-events: none; will-change: transform;
}

/* Gold section label variant */
.section-label-gold {
  color: var(--clr-gold);
  border-color: rgba(249,167,3,0.25);
  background: rgba(249,167,3,0.08);
}

/* Gold button variant */
.btn-gold {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: var(--sp-3) var(--sp-6);
  border-radius: var(--radius-full);
  font-size: var(--fs-sm); font-weight: 700;
  background: rgba(249,167,3,0.15);
  color: var(--clr-gold);
  border: 1px solid rgba(249,167,3,0.35);
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.btn-gold:hover {
  background: rgba(249,167,3,0.25);
  border-color: rgba(249,167,3,0.6);
  color: var(--clr-gold-light);
}

/* =========================================================
   SEARCH OVERLAY
   ========================================================= */

.search-overlay {
  position: fixed;
  inset: 0;
  z-index: 9900;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s ease;
}
.search-overlay.is-open {
  pointer-events: all;
  opacity: 1;
}

.search-overlay-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8, 14, 30, 0.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.search-overlay-panel {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 780px;
  margin: 0 var(--sp-4);
  margin-top: clamp(60px, 12vh, 120px);
  transform: translateY(-16px);
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.search-overlay.is-open .search-overlay-panel {
  transform: translateY(0);
}

/* Label */
.search-overlay-label {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--clr-gold);
  margin-bottom: var(--sp-5);
}

/* Input row */
.search-overlay-form {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  border-bottom: 2px solid rgba(255,255,255,0.15);
  padding-bottom: var(--sp-4);
  margin-bottom: var(--sp-6);
  transition: border-color 0.2s;
}
.search-overlay-form:focus-within {
  border-bottom-color: var(--clr-gold);
}

.search-overlay-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-family: var(--font-primary);
  font-size: clamp(1.5rem, 4vw, 2.25rem);
  font-weight: var(--fw-bold);
  color: var(--clr-white);
  caret-color: var(--clr-gold);
}
.search-overlay-input::placeholder {
  color: rgba(255,255,255,0.25);
}

.search-overlay-submit {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px; height: 48px;
  border-radius: var(--radius-full);
  border: none;
  background: var(--clr-gold);
  color: var(--clr-dark);
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}
.search-overlay-submit:hover {
  background: var(--clr-gold-light);
  transform: scale(1.05);
}

/* Close button */
.search-overlay-close {
  position: absolute;
  top: -48px;
  right: 0;
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.5);
  border-radius: var(--radius-md);
  padding: var(--sp-1) var(--sp-3);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.search-overlay-close:hover {
  background: rgba(255,255,255,0.12);
  color: var(--clr-white);
}

/* Quick links */
.search-quick-links {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-bottom: var(--sp-6);
}
.search-quick-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: rgba(255,255,255,0.35);
}
.search-quick-chip {
  display: inline-flex;
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius-full);
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.6);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semi);
  text-decoration: none;
  transition: background 0.18s, color 0.18s, border-color 0.18s;
}
.search-quick-chip:hover {
  background: rgba(249,167,3,0.12);
  border-color: rgba(249,167,3,0.35);
  color: var(--clr-gold);
}

/* Live suggestions */
.search-suggest { display: flex; flex-direction: column; gap: 2px; }

.suggest-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  text-decoration: none;
  transition: background 0.16s, border-color 0.16s, transform 0.16s;
  color: var(--clr-white);
}
.suggest-item:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(249,167,3,0.25);
  transform: translateX(4px);
}
.suggest-badge {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  padding: 2px var(--sp-2);
  border-radius: var(--radius-full);
  background: rgba(6,122,193,0.25);
  color: var(--clr-blue-light);
  white-space: nowrap;
}
.suggest-title {
  flex: 1;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.suggest-item svg { flex-shrink: 0; color: rgba(255,255,255,0.25); }
.suggest-item:hover svg { color: var(--clr-gold); }

.suggest-see-all {
  display: block;
  margin-top: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  text-align: center;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-gold);
  border: 1px dashed rgba(249,167,3,0.3);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background 0.18s, border-color 0.18s;
}
.suggest-see-all:hover {
  background: rgba(249,167,3,0.08);
  border-color: rgba(249,167,3,0.5);
}

/* =========================================================
   SEARCH RESULTS PAGE
   ========================================================= */

.search-page-form {
  margin-bottom: var(--sp-10);
}
.search-page-input-wrap {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  background: var(--clr-white);
  border: 2px solid var(--clr-border);
  border-radius: var(--radius-full);
  padding: var(--sp-3) var(--sp-3) var(--sp-3) var(--sp-5);
  box-shadow: var(--shadow-md);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.search-page-input-wrap:focus-within {
  border-color: var(--clr-blue);
  box-shadow: 0 0 0 4px rgba(6,122,193,0.1), var(--shadow-md);
}
.search-page-input-wrap svg { color: var(--clr-text-muted); flex-shrink: 0; }
.search-page-input {
  flex: 1;
  border: none;
  outline: none;
  font-family: var(--font-primary);
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  color: var(--clr-text-primary);
  background: transparent;
}
.search-page-input::placeholder { color: var(--clr-text-muted); }
.search-page-btn {
  flex-shrink: 0;
  padding: var(--sp-2) var(--sp-6);
  border-radius: var(--radius-full);
  border: none;
  background: var(--grad-primary);
  color: var(--clr-white);
  font-family: var(--font-primary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  cursor: pointer;
  transition: opacity 0.2s, transform 0.2s;
}
.search-page-btn:hover { opacity: 0.88; transform: scale(1.02); }

/* Result cards */
.search-results-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.search-result-card {
  display: block;
  padding: var(--sp-6);
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  text-decoration: none;
  color: inherit;
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.22s, border-color 0.22s, transform 0.22s;
}
.search-result-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--clr-blue);
  transform: translateY(-2px);
}
.src-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.src-badge {
  display: inline-flex;
  padding: 3px var(--sp-3);
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
}
.badge-blue  { background: var(--clr-blue-pale);   color: var(--clr-blue); }
.badge-green { background: #d1fae5;                 color: #065f46; }
.badge-gold  { background: var(--clr-gold-pale);    color: var(--clr-gold-dark); }
.badge-gray  { background: var(--clr-surface);      color: var(--clr-text-muted); }

.src-date {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
}
.src-title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--clr-text-primary);
  margin: 0 0 var(--sp-2);
  line-height: var(--lh-snug);
  transition: color 0.2s;
}
.search-result-card:hover .src-title { color: var(--clr-blue); }

.src-snippet {
  font-size: var(--fs-sm);
  color: var(--clr-text-secondary);
  line-height: var(--lh-relaxed);
  margin: 0 0 var(--sp-4);
}
.src-link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  color: var(--clr-blue);
  transition: gap 0.18s;
}
.search-result-card:hover .src-link { gap: var(--sp-2); }

/* highlight mark */
.search-mark {
  background: rgba(249,167,3,0.25);
  color: inherit;
  border-radius: 2px;
  padding: 0 1px;
}

/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 640px) {
  .search-overlay-panel { margin-top: var(--sp-10); }
  .search-overlay-close { top: -44px; }
  .search-overlay-input { font-size: 1.4rem; }
  .search-page-input-wrap { border-radius: var(--radius-xl); padding: var(--sp-2) var(--sp-2) var(--sp-2) var(--sp-4); }
  .search-page-btn { padding: var(--sp-2) var(--sp-4); font-size: var(--fs-xs); }
}

/* =========================================================
   ENHANCED RESPONSIVE â€” TABLET & MOBILE (all views)
   ========================================================= */

/* Global baseline: media always fits its container */
img, video { max-width: 100%; height: auto; }

/* Tables inside rich-text content must scroll, not overflow */
.content-body  table,
.content-card  table,
.prose         table,
.article-body  table,
.entry-content table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%; }

/* Iframes (maps, YouTube) in content areas */
.content-body  iframe,
.content-card  iframe,
.embed-wrapper iframe { max-width: 100%; }

/* Hyperlinks inside rich-text content — distinct color + hover underline */
.content-card .prose a,
.content-body a,
.article-body a,
.entry-content a {
    color: var(--clr-blue);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
    transition: color .15s;
}
.content-card .prose a:hover,
.content-body a:hover,
.article-body a:hover,
.entry-content a:hover {
    color: var(--clr-blue-deeper, #044f7e);
    text-decoration-thickness: 2px;
}

/* ── WordPress-imported content: paragraph spacing + image rounding ── */
.article-body p,
.entry-content p {
    margin-top: var(--sp-4);
    margin-bottom: var(--sp-6);
    line-height: 1.8;
}
.article-body p:first-child,
.entry-content p:first-child { margin-top: 0; }
.article-body p:last-child,
.entry-content p:last-child { margin-bottom: 0; }
/* Force gap between consecutive paragraphs (defeats margin-collapse) */
.article-body p + p,
.entry-content p + p { margin-top: var(--sp-6); }

.article-body h2, .entry-content h2 { margin: var(--sp-8) 0 var(--sp-4); font-size: var(--fs-2xl); font-weight: 700; }
.article-body h3, .entry-content h3 { margin: var(--sp-6) 0 var(--sp-3); font-size: var(--fs-xl); font-weight: 700; }
.article-body h4, .entry-content h4 { margin: var(--sp-5) 0 var(--sp-3); font-size: var(--fs-lg); font-weight: 600; }

.article-body ul, .article-body ol,
.entry-content ul, .entry-content ol { margin: 0 0 var(--sp-5) var(--sp-6); }
.article-body li, .entry-content li { margin-bottom: var(--sp-2); }

.article-body blockquote,
.entry-content blockquote {
    margin: var(--sp-5) 0;
    padding: var(--sp-4) var(--sp-5);
    border-left: 4px solid var(--clr-blue);
    background: var(--clr-blue-pale);
    color: var(--clr-text-secondary);
    font-style: italic;
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

/* ─── Post Gallery (auto-extracted when 2+ images in content) ──────── */
.post-gallery {
    margin: var(--sp-10) 0 var(--sp-6);
    padding: var(--sp-6);
    background: var(--clr-off-white, #f9fafb);
    border-radius: var(--radius-xl);
    border: 1px solid var(--clr-border, #e5e7eb);
}
.post-gallery-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: var(--sp-5);
    padding-bottom: var(--sp-3);
    border-bottom: 2px solid var(--clr-blue);
}
.post-gallery-label {
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    color: var(--clr-blue);
}
.post-gallery-count {
    font-size: var(--fs-xs);
    color: var(--clr-text-muted);
    font-weight: var(--fw-medium);
}
.post-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--sp-3);
}
.post-gallery-item { margin: 0; }
.post-gallery-btn {
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    background: var(--clr-surface, #f3f4f6);
    border-radius: var(--radius-md);
    overflow: hidden;
    cursor: pointer;
    aspect-ratio: 4 / 3;
    transition: transform .2s ease, box-shadow .2s ease;
}
.post-gallery-btn:hover,
.post-gallery-btn:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(6,122,193,0.18);
    outline: 2px solid var(--clr-blue);
    outline-offset: 2px;
}
.post-gallery-btn img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin: 0 !important;   /* override .article-body img rules above */
    border-radius: 0;
}
.post-gallery-item figcaption {
    font-size: var(--fs-xs);
    color: var(--clr-text-muted);
    margin-top: var(--sp-2);
    line-height: 1.4;
}

/* ─── Lightbox overlay (fullscreen image viewer) ───────────────────── */
.post-lightbox {
    position: fixed; inset: 0;
    z-index: 9999;
    background: rgba(0,0,0,0.92);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--sp-4);
}
.post-lightbox[hidden] { display: none; }
.post-lightbox-stage {
    position: relative;
    max-width: 92vw;
    max-height: 92vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-3);
}
.post-lightbox-stage img {
    max-width: 100%;
    max-height: 82vh;
    object-fit: contain;
    border-radius: var(--radius-md);
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.post-lightbox-caption {
    color: rgba(255,255,255,0.9);
    font-size: var(--fs-sm);
    text-align: center;
    max-width: 720px;
    line-height: 1.5;
}
.post-lightbox-counter {
    color: rgba(255,255,255,0.5);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wide);
}
.post-lightbox-close {
    position: absolute;
    top: var(--sp-4); right: var(--sp-4);
    width: 44px; height: 44px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    color: #fff;
    border-radius: 50%;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s;
}
.post-lightbox-close:hover { background: rgba(255,255,255,0.2); }
.post-lightbox-nav {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    width: 56px; height: 56px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.2);
    color: #fff;
    border-radius: 50%;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s;
}
.post-lightbox-nav:hover { background: rgba(255,255,255,0.2); }
.post-lightbox-prev { left: var(--sp-4); }
.post-lightbox-next { right: var(--sp-4); }
@media (max-width: 768px) {
    .post-lightbox-nav { width: 44px; height: 44px; }
    .post-lightbox-prev { left: var(--sp-2); }
    .post-lightbox-next { right: var(--sp-2); }
}

/* Inline images in WP content — applied via post-cover-img class injected server-side.
   IMPORTANT: override the tighter `.post-cover-img { margin: 0 0 2rem }` rule
   that's intended only for the thumbnail above the article title. Inline body
   images need full vertical breathing room. */
.article-body img,
.article-body .post-cover-img,
.entry-content img,
.entry-content .post-cover-img {
    margin: var(--sp-6) 0 !important;
    display: block;
}
.article-body figure, .entry-content figure { margin: var(--sp-6) 0; }
.article-body figure img, .entry-content figure img {
    margin: 0 !important;   /* figure handles outer spacing */
}
.article-body figcaption, .entry-content figcaption {
    font-size: var(--fs-sm);
    color: var(--clr-text-muted);
    text-align: center;
    margin-top: var(--sp-2);
}

/* Scroll-to-top button */
.scroll-to-top {
  position: fixed;
  bottom: var(--sp-6);
  right: var(--sp-6);
  width: 42px; height: 42px;
  background: var(--grad-primary);
  color: var(--clr-white);
  border: none;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-lg);
  opacity: 0; visibility: hidden;
  transform: translateY(12px);
  transition: opacity .3s, visibility .3s, transform .3s;
  z-index: 800;
}
.scroll-to-top.visible { opacity: 1; visibility: visible; transform: translateY(0); }
.scroll-to-top:hover   { filter: brightness(1.1); transform: translateY(-2px); }

/* â”€â”€â”€ Wide tablet / landscape iPad (â‰¤ 960px) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 960px) {
  /* News grids: 3-col â†’ 2-col before full collapse */
  .news-grid          { grid-template-columns: repeat(2, 1fr); }
  .news-grid-featured { grid-template-columns: 1fr 1fr; }
}

/* â”€â”€â”€ Tablet additions (â‰¤ 768px) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 768px) {
  /* Override featured grid to single column */
  .news-grid-featured { grid-template-columns: 1fr; }

  /* Footer bottom: center-align on mobile */
  .footer-bottom       { flex-direction: column; text-align: center; }
  .footer-bottom-links { justify-content: center; flex-wrap: wrap; gap: var(--sp-3); }

  /* Sidebar nav: ensure pill tags wrap cleanly */
  .sidebar-nav-body { padding: var(--sp-3); }

  /* Scroll-to-top: closer to edge on small screen */
  .scroll-to-top { bottom: var(--sp-4); right: var(--sp-4); width: 38px; height: 38px; }

  /* i4 programs: 2-col on tablet (was auto-fill) */
  .i4-programs-grid { grid-template-columns: repeat(2, 1fr); }
}

/* â”€â”€â”€ Phone landscape (â‰¤ 640px) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 640px) {
  /* i4 / i2 floating hero card: hide on phone */
  .i4-hero-card    { display: none; }
  .i2-hero-card    { display: none !important; }

  /* i4 / i3 CTA: stack vertically */
  .i4-cta-inner,
  .i3-cta-inner { flex-direction: column; align-items: flex-start; gap: var(--sp-6); }

  /* i4 section header action buttons: stretch full width */
  .i4-section-header .btn,
  .i4-editorial-header .btn { width: 100%; justify-content: center; }

  /* Inovasi chip row: tighter on phone */
  .i4-inovasi-chip    { font-size: .72rem; padding: .25rem .6rem; }
  .i4-inovasi-see-all { margin-left: 0; }
  .i4-inovasi-row     { gap: var(--sp-2); }

  /* Book shelf: medium shrink */
  .book-card  { width: 140px; }
  .book-cover { width: 140px; height: 196px; }
  .book-title { max-width: 140px; font-size: 11px; }
  .shelf-row  { gap: 14px; }

  /* Service quick-access chips: force 2-col */
  .prg-chips-row { grid-template-columns: repeat(2, 1fr) !important; }

  /* i4 programs: 1-col */
  .i4-programs-grid { grid-template-columns: 1fr; }

  /* Search result card: compact */
  .search-result-card { padding: var(--sp-4); }
  .src-title          { font-size: var(--fs-base); }

  /* News card: compact body */
  .news-card-body  { padding: var(--sp-4); }

  /* data-capaian: 2-col */
  .data-capaian-grid { grid-template-columns: repeat(2, 1fr); }

  /* Inner hero: center for better phone presentation */
  .inner-hero             { text-align: center; }
  .inner-hero-breadcrumb  { justify-content: center; }
  .breadcrumb             { justify-content: center; flex-wrap: wrap; }

  /* Stat grid: 2-col max */
  .stats-grid { grid-template-columns: repeat(2, 1fr); }

  /* Section header: ensure stacked buttons don't overflow */
  .i2-section-header { flex-direction: column; align-items: flex-start; gap: var(--sp-3); }
}

/* â”€â”€â”€ Small phone (â‰¤ 480px) additions â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 480px) {
  /* prg-chips-row (not covered by services-grid !important) */
  .prg-chips-row  { grid-template-columns: repeat(2, 1fr) !important; }

  /* Book shelf: smallest size */
  .book-card  { width: 120px; }
  .book-cover { width: 120px; height: 168px; }
  .book-title { max-width: 120px; font-size: 10px; }
  .shelf-row  { gap: 10px; }

  /* Article item body: tighter */
  .article-item-body  { padding: var(--sp-4); }
  .article-item-title { font-size: var(--fs-sm); }

  /* News card: minimal */
  .news-card-title { -webkit-line-clamp: 2; }

  /* Stat numbers: scale down */
  .stat-number { font-size: clamp(1.8rem, 8vw, 2.5rem); }
  .stat-item   { padding: var(--sp-4) var(--sp-2); }

  /* Section: tighter top/bottom */
  .section { padding: var(--sp-12) 0; }

  /* Footer socials: tighter gap */
  .footer-socials { gap: var(--sp-2); }

  /* Scroll-to-top even smaller */
  .scroll-to-top { width: 36px; height: 36px; }
}

/* =========================================================
   i4-HERO-CARD: Compact / Slim Override (DESKTOP ONLY)
   ---------------------------------------------------------
   Scoped to desktop (>1024px) so it does NOT override the
   single-column responsive rule for tablet/mobile.
   ========================================================= */
@media (min-width: 1025px) {
  .i4-hero-layout        { grid-template-columns: 1fr 240px; }
  .i4-hero-card          { padding: 1.5rem 1.25rem 1.25rem; }
  .i4-hero-card-icon     { width: 38px; height: 38px; margin-bottom: .75rem; }
  .i4-hero-card-icon svg { width: 20px; height: 20px; }
  .i4-hero-card-num      { font-size: clamp(2rem, 3.5vw, 2.8rem); }
  .i4-hero-card-ring     { inset: -12px; }
}

/* =========================================================
   SHARED â€” Dot Navigation (index homepage)
   ========================================================= */
.idx-dotnav {
  position: fixed; right: 1.5rem; top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 10px;
  z-index: 900; pointer-events: none;
}
/* WCAG 2.5.8: button hit area 24x24 (transparent), visible dot stays 8x8 via ::before */
.idx-dot {
  width: 24px; height: 24px;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer; pointer-events: all;
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.idx-dot::before {
  content: '';
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(255,255,255,0.35);
  border: 1.5px solid rgba(255,255,255,0.55);
  transition: background .3s, transform .3s, border-color .3s;
}
.idx-dot::after {
  content: attr(data-label);
  position: absolute; right: 26px; top: 50%; transform: translateY(-50%);
  background: rgba(10,20,40,0.82); color: #fff;
  font-size: 11px; font-weight: 600; white-space: nowrap;
  padding: 3px 9px; border-radius: 4px;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.idx-dot:hover::after,
.idx-dot:focus-visible::after { opacity: 1; }
.idx-dot.active::before {
  background: var(--clr-blue);
  border-color: var(--clr-blue);
  transform: scale(1.4);
}
/* switch dots to dark color on light sections */
.idx-dot.dark-dot::before {
  background: rgba(10,20,40,0.25);
  border-color: rgba(10,20,40,0.4);
}
.idx-dot.dark-dot.active::before {
  background: var(--clr-blue);
  border-color: var(--clr-blue);
}
@media (max-width: 768px) { .idx-dotnav { display: none; } }

/* =========================================================
   SHARED â€” Bento Editorial Grid (used in Index.cshtml Â§5)
   ========================================================= */
.idx-bento-grid {
  display: grid;
  grid-template-columns: 2.2fr 1fr 1.1fr;
  grid-template-rows: auto auto auto;
  grid-template-areas:
    "feat news1 glass"
    "feat news2 glass"
    "feat siar  glass";
  gap: 1rem;
  margin-top: var(--sp-8);
}
.idx-bento-cell {
  border-radius: var(--radius-xl);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform .25s, box-shadow .25s;
  display: flex; flex-direction: column;
}
.idx-bento-cell:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }

/* Featured large cell */
.idx-bento-featured {
  grid-area: feat;
  position: relative;
  min-height: 380px;
  background: var(--clr-off-white);
}
.idx-bento-featured-img {
  position: absolute; inset: 0;
  object-fit: cover; width: 100%; height: 100%;
  transition: transform .5s;
}
.idx-bento-featured:hover .idx-bento-featured-img { transform: scale(1.04); }
.idx-bento-featured-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(4,14,36,.88) 0%, rgba(4,14,36,.2) 60%, transparent 100%);
}
.idx-bento-featured-body {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 1.5rem 1.5rem 1.25rem;
  color: #fff;
}
.idx-bento-cat {
  display: inline-block;
  font-size: 0.65rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .08em;
  background: var(--clr-blue); color: #fff;
  padding: 2px 9px; border-radius: 3px;
  margin-bottom: .6rem;
}
.idx-bento-cat.gold { background: var(--clr-gold); color: #3a2000; }
.idx-bento-cat.green { background: #16a34a; color: #fff; }
.idx-bento-featured-title {
  font-size: clamp(1rem, 2vw, 1.3rem);
  font-weight: 800; line-height: 1.3; color: #fff;
  margin-bottom: .4rem;
}
.idx-bento-date { font-size: .68rem; color: rgba(255,255,255,.55); }

/* Small news cells */
.idx-bento-news {
  background: var(--clr-white);
  border: 1px solid var(--clr-border);
  padding: 1rem 1.1rem;
  gap: .4rem;
}
.idx-bento-news-title {
  font-size: .825rem; font-weight: 700;
  color: var(--clr-text-primary); line-height: 1.4;
  flex: 1;
}
.idx-bento-news-date { font-size: .65rem; color: var(--clr-text-muted); margin-top: auto; }
.idx-bento-news:hover .idx-bento-news-title { color: var(--clr-blue); }

/* Siaran pers cell */
.idx-bento-siaran {
  background: var(--clr-off-white);
  border: 1px solid var(--clr-border);
  padding: 1rem 1.1rem;
  gap: .4rem;
}
.idx-bento-siaran-title {
  font-size: .8rem; font-weight: 700;
  color: var(--clr-text-primary); line-height: 1.4;
}
.idx-bento-siaran-date { font-size: .65rem; color: var(--clr-text-muted); }

/* Glass sidebar cell (artikel list) */
.idx-bento-glass {
  grid-area: glass;
  background: linear-gradient(160deg, rgba(6,122,193,.06) 0%, rgba(6,122,193,.02) 100%);
  border: 1px solid rgba(6,122,193,.15);
  padding: 0;
  display: flex; flex-direction: column;
  color: inherit; text-decoration: none;
}
.idx-bento-glass-head {
  padding: .9rem 1.1rem;
  font-size: .68rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--clr-blue);
  background: rgba(6,122,193,.06);
  border-bottom: 1px solid rgba(6,122,193,.12);
}
.idx-bento-glass-item {
  display: block; padding: .8rem 1.1rem;
  border-bottom: 1px solid var(--clr-border);
  text-decoration: none; color: inherit;
  transition: background .15s;
}
.idx-bento-glass-item:last-child { border-bottom: none; }
.idx-bento-glass-item:hover { background: rgba(6,122,193,.05); }
.idx-bento-glass-item-date { font-size: .63rem; color: var(--clr-text-muted); margin-bottom: .2rem; }
.idx-bento-glass-item-title { font-size: .78rem; font-weight: 700; color: var(--clr-text-primary); line-height: 1.4; }
.idx-bento-glass-item:hover .idx-bento-glass-item-title { color: var(--clr-blue); }
.idx-bento-glass-footer {
  margin-top: auto;
  padding: .75rem 1.1rem;
  font-size: .72rem; font-weight: 700;
  color: var(--clr-blue); text-decoration: none;
  background: rgba(6,122,193,.04);
  border-top: 1px solid rgba(6,122,193,.12);
  display: block;
}
.idx-bento-glass-footer:hover { background: rgba(6,122,193,.1); }

/* Responsive bento */
@media (max-width: 1024px) {
  .idx-bento-grid {
    grid-template-columns: 1.6fr 1fr;
    grid-template-areas:
      "feat glass"
      "news1 glass"
      "news2 siar";
  }
}
@media (max-width: 640px) {
  .idx-bento-grid {
    grid-template-columns: 1fr;
    grid-template-areas:
      "feat"
      "news1"
      "news2"
      "glass"
      "siar";
  }
  .idx-bento-featured { min-height: 260px; }
}

/* =========================================================
   i4-SEARCH CTA SECTION
   ========================================================= */
.i4-search-cta { max-width: 700px; margin: 0 auto; }

.i4-search-bar-form { margin-bottom: var(--sp-5); }
.i4-search-bar-wrap {
  display: flex; align-items: center;
  background: rgba(255,255,255,0.08);
  border: 1.5px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-2xl);
  padding: .4rem .4rem .4rem 1.25rem;
  gap: .75rem;
  transition: border-color .25s, background .25s;
}
.i4-search-bar-wrap:focus-within {
  border-color: var(--clr-blue-light);
  background: rgba(255,255,255,0.12);
}
.i4-search-bar-icon { color: rgba(255,255,255,0.4); flex-shrink: 0; }
.i4-search-bar-input {
  flex: 1; background: none; border: none; outline: none;
  color: #fff; font-size: var(--fs-md); font-family: inherit;
  padding: .6rem 0;
}
.i4-search-bar-input::placeholder { color: rgba(255,255,255,0.3); }
.i4-search-bar-btn {
  display: inline-flex; align-items: center; gap: .4rem;
  background: var(--clr-blue);
  color: #fff; font-size: var(--fs-sm); font-weight: var(--fw-bold);
  padding: .7rem 1.4rem; border-radius: var(--radius-xl);
  border: none; cursor: pointer; flex-shrink: 0;
  transition: background .2s;
}
.i4-search-bar-btn:hover { background: var(--clr-blue-dark); }

.i4-search-tags {
  display: flex; align-items: center; gap: .5rem;
  flex-wrap: wrap; justify-content: center;
}
.i4-search-tag {
  display: inline-flex; align-items: center;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  color: rgba(255,255,255,0.7);
  font-size: var(--fs-xs); font-weight: var(--fw-semi);
  padding: .3rem .85rem; border-radius: var(--radius-full);
  text-decoration: none;
  transition: background .2s, color .2s, border-color .2s;
}
.i4-search-tag:hover {
  background: rgba(255,255,255,0.15);
  border-color: rgba(255,255,255,0.3);
  color: #fff;
}
@media (max-width: 640px) {
  .i4-search-bar-wrap { flex-wrap: wrap; border-radius: var(--radius-xl); padding: .75rem 1rem; }
  .i4-search-bar-btn { width: 100%; justify-content: center; }
  .i4-search-bar-input { width: 100%; }
}

/* =========================================================
   BLUE DOTS ORNAMENT â€” decorative corner pattern
   ========================================================= */
.i4-dots-ornament {
  position: absolute;
  width: 140px; height: 140px;
  background-image: radial-gradient(circle, rgba(6,122,193,0.22) 1.5px, transparent 1.5px);
  background-size: 18px 18px;
  border-radius: 50%;
  pointer-events: none;
  opacity: .7;
}
/* Positions */
.i4-dots-tr { top: 2.5rem; right: 2.5rem; }
.i4-dots-bl { bottom: 2.5rem; left: 2.5rem; }
.i4-dots-tl { top: 2.5rem; left: 2.5rem; }
.i4-dots-br { bottom: 2.5rem; right: 2.5rem; }
/* Program Prioritas: dots ornament flush with the rounded top edge */
.i4-programs .i4-dots-tr { top: 0; }
/* Lighter for dark-bg sections */
.i4-cta .i4-dots-ornament {
  background-image: radial-gradient(circle, rgba(255,255,255,0.12) 1.5px, transparent 1.5px);
  opacity: .8;
}
@media (max-width: 640px) { .i4-dots-ornament { width: 90px; height: 90px; background-size: 14px 14px; } }

/* =========================================================
   DARK TOP ZONE â€” hero + ticker + search flow seamlessly
   ========================================================= */
.i4-page-top {
  background: var(--clr-dark);
  position: relative;
}
/* Search section inside dark zone: standalone, no stacking chrome */
.i4-cta {
  position: relative;
  overflow: hidden;
  padding: 4.5rem 0;
}

/* =========================================================
   FONT RESIZER (navbar) â€” single trigger + dropdown
   ========================================================= */
.nav-font-sizer {
  position: relative;
  display: inline-flex; align-items: center;
}

/* Trigger button: single "A" — match .nav-search-btn (40x40, theme-aware) */
.nav-font-trigger {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border-radius: var(--radius-full);
  border: none;
  background: transparent;
  color: var(--clr-text-primary);
  font-weight: 800;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.nav-font-trigger:hover {
  background: rgba(6,122,193,0.1);
  color: var(--clr-blue);
  transform: scale(1.08);
}
.nav-font-trigger.active {
  background: var(--clr-blue-pale);
  color: var(--clr-blue);
}
/* Transparent nav (hero) state — match search button styling */
.site-nav:not(.scrolled):not(.nav-solid) .nav-font-trigger {
  color: rgba(255,255,255,0.85);
}
.site-nav:not(.scrolled):not(.nav-solid) .nav-font-trigger:hover {
  background: rgba(255,255,255,0.12);
  color: var(--clr-white);
}
.site-nav:not(.scrolled):not(.nav-solid) .nav-font-trigger.active {
  background: rgba(255,255,255,0.2);
  color: var(--clr-white);
}

/* Dropdown panel */
.nav-font-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  background: #fff;
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  box-shadow: 0 8px 32px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.06);
  display: flex; flex-direction: column; align-items: center;
  gap: 2px; padding: 6px;
  min-width: 42px;
  opacity: 0; transform: translateY(-6px) scale(.96);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
  z-index: 1000;
}
.nav-font-dropdown.open {
  opacity: 1; transform: translateY(0) scale(1);
  pointer-events: auto;
}

/* Dropdown buttons */
.nav-font-drop-btn {
  display: inline-flex; align-items: center; justify-content: center;
  background: none; border: none; cursor: pointer;
  color: var(--clr-text-secondary);
  font-weight: 800;
  width: 30px; height: 30px;
  border-radius: var(--radius-lg);
  transition: background .15s, color .15s;
}
.nav-font-drop-btn:first-child { font-size: 0.88rem; }
.nav-font-drop-btn:nth-child(2) { font-size: 0.78rem; }
.nav-font-drop-btn:last-child  { font-size: 0.68rem; }
.nav-font-drop-btn sup, .nav-font-drop-btn sub { font-size: .55em; font-weight: 900; }
.nav-font-drop-btn:hover:not(:disabled) { background: var(--clr-blue-pale); color: var(--clr-blue); }
.nav-font-drop-btn:disabled { opacity: .3; cursor: default; }
.nav-font-drop-btn.active { color: var(--clr-blue); background: var(--clr-blue-pale); }

@media (max-width: 480px) { .nav-font-sizer { display: none; } }



/* =========================================================
   RUANG PENGADUAN â€” sidebar cards (rendered from CMS SidebarHtml)
   ========================================================= */
.pengaduan-sidebar {
  display:flex; flex-direction:column; gap:var(--sp-5);
}
.pengaduan-sidebar > div,
.pengaduan-info-card,
.pengaduan-help-card {
  background:var(--clr-white);
  border:1px solid var(--clr-border);
  border-radius:var(--radius-xl);
  padding:var(--sp-6);
}
.pengaduan-info-card h4,
.pengaduan-help-card h4 {
  font-size:var(--fs-base); font-weight:var(--fw-bold);
  color:var(--clr-blue); margin:0 0 var(--sp-3); text-transform:none; letter-spacing:0;
}
.pengaduan-info-card p,
.pengaduan-help-card p {
  font-size:var(--fs-sm); color:var(--clr-text-secondary);
  line-height:var(--lh-relaxed); margin:0 0 var(--sp-3);
}
.pengaduan-info-card p:last-child,
.pengaduan-help-card p:last-child { margin-bottom:0; }
.pengaduan-info-card a {
  color:var(--clr-blue); text-decoration:none; font-weight:var(--fw-semi);
  border-bottom:1px solid rgba(6,122,193,.25); transition:color .15s, border-color .15s;
}
.pengaduan-info-card a:hover { color:var(--clr-blue-deep,#053060); border-bottom-color:var(--clr-blue); }
.pengaduan-help-card {
  background:var(--clr-blue-pale); border-color:rgba(6,122,193,0.2);
}
.pengaduan-help-contact {
  font-size:var(--fs-sm); font-weight:var(--fw-semi);
  color:var(--clr-blue); margin:var(--sp-2) 0 0 !important;
}


/* =========================================================
   PENGADUAN CHANNELS â€” Hub + Detail (selaras theme site)
   ========================================================= */

/* Section padding standar â€” sama dengan section lain di site */
.pengaduan-section { padding: var(--sp-16) 0 var(--sp-24); }
.pengaduan-section .content-card { margin-bottom: var(--sp-6); }
.pengaduan-section .content-card:last-child { margin-bottom: 0; }

/* Detail page layout: main + sidebar 340px (sama dengan ProgramDetail) */
.pengaduan-detail-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: var(--sp-8);
    align-items: flex-start;
}
.pengaduan-detail-main { display: flex; flex-direction: column; gap: var(--sp-5); }
.pengaduan-detail-sidebar {
    display: flex; flex-direction: column; gap: var(--sp-4);
    position: sticky; top: calc(var(--nav-height) + var(--sp-4));
}

/* Quick info rows in sidebar (re-used from sidebar pattern) */
.pengaduan-detail-sidebar .info-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: var(--sp-3) 0;
    border-bottom: 1px solid var(--clr-border);
    font-size: var(--fs-sm);
}
.pengaduan-detail-sidebar .info-row:last-of-type { border-bottom: 0; }
.pengaduan-detail-sidebar .info-row span { color: var(--clr-text-muted); }
.pengaduan-detail-sidebar .info-row strong { color: var(--clr-text-primary); text-align: right; }

/* Privacy section â€” kuning callout */
.pengaduan-privacy {
    background: linear-gradient(135deg, #fffbeb 0%, var(--clr-white) 100%) !important;
    border-left: 4px solid var(--clr-gold) !important;
}

/* How-to ordered list â€” auto-style steps (numbered cards) */
.pengaduan-howto ol { counter-reset: step; list-style: none; padding: 0; margin: 0; }
.pengaduan-howto ol li {
    counter-increment: step;
    background: var(--clr-off-white);
    border-left: 4px solid var(--clr-blue);
    border-radius: var(--radius-md);
    padding: var(--sp-4) var(--sp-5) var(--sp-4) calc(var(--sp-5) + 36px);
    margin-bottom: var(--sp-3);
    position: relative;
    line-height: var(--lh-relaxed);
    color: var(--clr-text-secondary);
}
.pengaduan-howto ol li::before {
    content: counter(step);
    position: absolute;
    left: var(--sp-3);
    top: var(--sp-4);
    width: 28px; height: 28px;
    background: var(--clr-blue);
    color: var(--clr-white);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-weight: var(--fw-bold);
    font-size: var(--fs-xs);
}

/* Related channel item (sidebar) */
.related-channel-item {
    display: flex; align-items: center; gap: var(--sp-3);
    padding: var(--sp-2) var(--sp-3);
    border-radius: var(--radius-md);
    text-decoration: none;
    color: var(--clr-text-primary);
    transition: background .15s;
}
.related-channel-item:hover { background: var(--clr-off-white); }
.related-channel-icon {
    width: 36px; height: 36px;
    border-radius: var(--radius-md);
    background: var(--clr-blue-pale);
    display: flex; align-items: center; justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}
.related-channel-item > span:last-child {
    min-width: 0;
    flex: 1;
    overflow: hidden;
}
.related-channel-item strong {
    display: block;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semi);
    line-height: 1.3;
    word-wrap: break-word;
    overflow-wrap: anywhere;
}
.related-channel-desc {
    display: block;
    font-size: 11px;
    color: var(--clr-text-muted);
    margin-top: 2px;
    line-height: 1.4;
    word-wrap: break-word;
    overflow-wrap: anywhere;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

@media (max-width: 900px) {
    .pengaduan-detail-layout { grid-template-columns: 1fr; }
    .pengaduan-detail-sidebar { position: static; }
}

/* â”€â”€ FAQ channel â€” search + accordion â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.pengaduan-faq-search .faq-search-wrap {
    position: relative;
    margin-top: var(--sp-3);
}
.pengaduan-faq-search .faq-search-icon {
    position: absolute;
    left: var(--sp-3);
    top: 50%;
    transform: translateY(-50%);
    color: var(--clr-text-muted);
    pointer-events: none;
}
.pengaduan-faq-search input[type="search"] {
    width: 100%;
    padding: 12px 14px 12px 42px;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: var(--radius-md);
    background: var(--clr-white);
    font-size: var(--fs-md);
    color: var(--clr-text-primary);
    transition: border-color .15s, box-shadow .15s;
}
.pengaduan-faq-search input[type="search"]:focus {
    outline: none;
    border-color: var(--clr-blue);
    box-shadow: 0 0 0 3px rgba(6, 122, 193, 0.15);
}
.pengaduan-faq-search .faq-search-meta {
    margin: var(--sp-2) 0 0;
    font-size: var(--fs-xs);
    color: var(--clr-text-muted);
}

.pengaduan-faq-group .accent-line { margin-bottom: var(--sp-4); }

.faq-list {
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
}
.faq-item {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: var(--radius-md);
    background: var(--clr-white);
    overflow: hidden;
    transition: border-color .15s, box-shadow .15s;
}
.faq-item:hover { border-color: var(--clr-blue); }
.faq-item[open] {
    border-color: var(--clr-blue);
    box-shadow: 0 2px 8px rgba(6, 122, 193, 0.08);
}
.faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: var(--sp-4) var(--sp-5);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--sp-4);
    font-weight: var(--fw-semi);
    color: var(--clr-text-primary);
    font-size: var(--fs-md);
    line-height: 1.5;
    user-select: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:focus-visible {
    outline: 2px solid var(--clr-blue);
    outline-offset: -2px;
}
.faq-q-text { flex: 1; min-width: 0; }
.faq-icon {
    flex-shrink: 0;
    color: var(--clr-blue);
    transition: transform .2s ease;
    display: inline-flex;
    margin-top: 2px;
}
.faq-item[open] .faq-icon { transform: rotate(180deg); }
.faq-answer {
    padding: 0 var(--sp-5) var(--sp-5);
    color: var(--clr-text-secondary);
    border-top: 1px solid var(--clr-off-white, #f3f4f6);
    padding-top: var(--sp-4);
    margin-top: 0;
}
.faq-answer p:first-child { margin-top: 0; }
.faq-answer p:last-child { margin-bottom: 0; }
.faq-answer ul, .faq-answer ol { margin: var(--sp-2) 0; padding-left: var(--sp-5); }
.faq-answer li { margin-bottom: var(--sp-1); }

@media (prefers-reduced-motion: reduce) {
    .faq-item, .faq-icon { transition: none; }
}

.pengaduan-help-big {
  font-size:var(--fs-2xl); font-weight:var(--fw-black);
  color:var(--clr-gold-dark); margin:0 !important; line-height:1;
}
@media (max-width:768px){
  .pengaduan-layout { grid-template-columns: 1fr !important; }
}

/* Program year filter (Layanan/ProgramPrioritas, ProgramInovasi) */
.program-year-filter {
  display:flex; flex-wrap:wrap; align-items:center; gap:var(--sp-3);
  background:var(--clr-white); border:1px solid var(--clr-border);
  border-radius:var(--radius-full); padding:.55rem .9rem .55rem 1.1rem;
  margin:var(--sp-6) auto var(--sp-8); width:fit-content;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
}
.program-year-filter label {
  font-size:var(--fs-xs); font-weight:var(--fw-semi); color:var(--clr-text-secondary);
  text-transform:uppercase; letter-spacing:.05em; margin:0;
}
.program-year-filter select {
  font-size:var(--fs-sm); font-family:var(--font-primary); font-weight:var(--fw-semi);
  color:var(--clr-blue); background:var(--clr-blue-pale);
  border:1px solid rgba(6,122,193,.18); border-radius:var(--radius-md);
  padding:.4rem 2.2rem .4rem .85rem; cursor:pointer;
  appearance:none;
  background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23067ac1' stroke-width='3'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
  background-repeat:no-repeat; background-position:right .65rem center; background-size:12px;
  transition:border-color .15s, background-color .15s;
}
.program-year-filter select:hover,
.program-year-filter select:focus {
  border-color:var(--clr-blue); outline:none;
  box-shadow:0 0 0 3px rgba(6,122,193,.12);
}
.program-year-reset {
  font-size:var(--fs-xs); font-weight:var(--fw-semi); color:var(--clr-text-muted);
  text-decoration:none; padding:.3rem .65rem; border-radius:var(--radius-full);
  transition:background .15s, color .15s;
}
.program-year-reset:hover { background:var(--clr-off-white); color:var(--clr-blue); }

/* Admin: program year multi-select checkbox grid */
.program-year-checks {
  display:flex; flex-wrap:wrap; gap:.5rem;
  padding:.6rem; background:#f8fafc; border:1px solid var(--clr-border,#e5e7eb);
  border-radius:.5rem;
}
.program-year-check {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.35rem .7rem; border-radius:999px;
  background:#fff; border:1px solid var(--clr-border,#e5e7eb);
  cursor:pointer; font-size:.85rem; font-weight:500;
  transition:background .15s, border-color .15s, color .15s;
}
.program-year-check input { margin:0; accent-color:var(--clr-blue,#067ac1); }
.program-year-check:hover { border-color:rgba(6,122,193,.4); }
.program-year-check input:checked + span {
  color:var(--clr-blue,#067ac1); font-weight:700;
}
.program-year-check:has(input:checked) {
  background:var(--clr-blue-pale,#e8f3fc); border-color:var(--clr-blue,#067ac1);
}

/* Connector above the search section sits below the ticker badges to avoid overlap.
   Default connector center is at top:-26px and particles at top:-22px (both straddle
   the seam upward). The ticker bar above is ~60px tall + badge content â€” push the
   dot well below the seam so it sits clearly inside the search section. */
.i4-connector--search .i4-conn-center   { top: 60px; }
.i4-connector--search .i4-conn-particle { top: 64px; }


/* =========================================================
   ACCESSIBILITY (WCAG 2.2 â€” Phase 1)
   --------------------------------------------------------
   This block adds invisible (to mouse users) a11y enhancements.
   ========================================================= */

/* â”€â”€ Visually hidden utility (screen-reader-only text) â”€â”€â”€â”€â”€ */
.visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* â”€â”€ Keyboard focus visible styles (WCAG 2.4.7, 2.4.11) â”€â”€â”€â”€ */
/* Outline only when navigating via keyboard, not on mouse click */
*:focus-visible {
  outline: 3px solid var(--clr-blue, #067ac1);
  outline-offset: 2px;
  border-radius: 2px;
}
/* Suppress focus outline on mouse interactions */
*:focus:not(:focus-visible) {
  outline: none;
}
/* Custom focus for items on dark/blue backgrounds â€” use gold for contrast */
.site-nav *:focus-visible,
.search-overlay *:focus-visible,
.site-footer *:focus-visible,
.back-to-top:focus-visible {
  outline-color: var(--clr-gold, #f9a703);
  outline-offset: 3px;
}
/* Inputs already have border treatment â€” keep outline subtle but visible */
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline-offset: 1px;
}
/* Main landing target after skip link â€” no visible outline on the
   landmark itself, just programmatic focus */
main[tabindex="-1"]:focus,
main[tabindex="-1"]:focus-visible {
  outline: none;
}

/* â”€â”€ Active page indicator (paired with aria-current="page") â”€ */
.nav-link[aria-current="page"] {
  font-weight: 700;
}

/* â”€â”€ Form validation error message (WCAG 3.3.1, 3.3.3) â”€â”€â”€â”€ */
/* Replaces inline `style="font-size:12px;"` and gives errors clear identity */
.field-error {
  display: block;
  margin-top: 4px;
  font-size: 0.8125rem;
  line-height: 1.4;
  color: #b91c1c;
  font-weight: 500;
}
.field-error:empty {
  display: none;
}
.field-error::before {
  content: 'âš  ';
  margin-right: 2px;
}
.field-error:empty::before {
  content: none;
}

/* â”€â”€ Success / alert message (replaces inline styles) â”€â”€â”€â”€â”€ */
.alert {
  padding: 1rem 1.25rem;
  border-radius: 8px;
  margin-bottom: 1.5rem;
  border: 1px solid transparent;
  line-height: 1.5;
}
.alert-success {
  background: #dcfce7;
  border-color: #86efac;
  color: #166534;
}
.alert-error,
.alert-danger {
  background: #fee2e2;
  border-color: #fca5a5;
  color: #991b1b;
}

/* â”€â”€ Required indicator: hide pseudo asterisk from screen readers â”€â”€â”€ */
/* The HTML `required` attribute already conveys this to assistive tech;
   the visual `*` is for sighted users only. */
.form-label.required::after {
  speak: none;             /* legacy, kept for older readers */
  /* aria-hidden equivalent not possible on pseudo â€” rely on `required` attr */
}

/* â”€â”€ Full-width submit button (replaces inline width:100%) â”€ */
.btn-submit-full {
  width: 100%;
  justify-content: center;
  margin-top: var(--sp-4, 1rem);
}

/* â”€â”€ Sticky header offset for in-page anchors (WCAG 2.4.11) â”€ */
/* When clicking anchor links or skip-link, ensure focused element
   is NOT hidden under the sticky header. */
:target,
[id]:focus {
  scroll-margin-top: 96px;
}
#main-content {
  scroll-margin-top: 0;
}

/* â”€â”€ Minimum touch target (WCAG 2.5.8 â€” WCAG 2.2 NEW) â”€â”€â”€ */
/* Apply only to interactive controls that are NOT inline within text.
   Excludes inline links inside prose (1.1 baseline acceptable exception). */
button:not(.dropdown-item):not(.nav-link):not(.mobile-submenu-item):not([class*="-link"]),
[role="button"]:not([class*="-link"]),
input[type="checkbox"],
input[type="radio"] {
  min-height: 24px;
  min-width: 24px;
}

/* â”€â”€ Reduced motion preference (WCAG 2.3.3) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Respect OS-level "reduce motion" setting (vestibular accessibility) */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  /* Disable parallax / fancy entrance effects entirely */
  [data-aos] {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* â”€â”€ PPID Informasi Berkala / Serta Merta / Setiap Saat â€” numbered list â”€â”€
   Selectors prefixed with .content-card to beat existing .content-card ol
   rules (list-style:disc, margins) that would otherwise win on specificity. */
.content-card ol.ib-list,
.content-card .ib-list {
    list-style: none !important;
    counter-reset: none;
    padding: 0 !important;
    margin: var(--sp-5) 0 0 !important;
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
}
.content-card .ib-list .ib-item {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-4);
    padding: var(--sp-4) var(--sp-5);
    margin: 0 !important;
    background: var(--clr-white);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-left: 4px solid var(--clr-blue);
    border-radius: var(--radius-md);
    list-style: none !important;
    transition: border-color .15s, box-shadow .15s, transform .15s;
}
.content-card .ib-list .ib-item::marker { content: ""; }
.content-card .ib-list .ib-item:hover {
    border-color: var(--clr-blue);
    box-shadow: 0 2px 8px rgba(6, 122, 193, 0.08);
    transform: translateX(2px);
}
.content-card .ib-list .ib-num {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--clr-blue-pale);
    color: var(--clr-blue);
    font-weight: var(--fw-bold);
    font-size: var(--fs-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.content-card .ib-list .ib-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
}
.content-card .ib-list .ib-title {
    font-weight: var(--fw-semi);
    color: var(--clr-text-primary);
    line-height: 1.5;
    word-wrap: break-word;
}
.content-card .ib-list .ib-link {
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--radius-sm, 6px);
    background: var(--clr-blue-pale);
    color: var(--clr-blue);
    font-size: var(--fs-xs);
    font-weight: var(--fw-semi);
    text-decoration: none;
    transition: background .15s, color .15s;
}
.content-card .ib-list .ib-link:hover {
    background: var(--clr-blue);
    color: var(--clr-white);
}
.content-card .ib-list .ib-link--soon {
    background: var(--clr-off-white, #f3f4f6);
    color: var(--clr-text-muted);
    cursor: default;
}
.content-card .ib-list .ib-link--soon:hover {
    background: var(--clr-off-white, #f3f4f6);
    color: var(--clr-text-muted);
}
.content-card .ib-list .ib-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-2);
}
.content-card .ib-list .ib-link--ghost {
    background: transparent;
    border: 1px solid var(--clr-blue-pale);
    color: var(--clr-blue);
}
.content-card .ib-list .ib-link--ghost:hover {
    background: var(--clr-blue);
    color: var(--clr-white);
    border-color: var(--clr-blue);
}

/* PPID Layanan — infografis landscape */
.layanan-infografis {
    margin: var(--sp-5) 0 0;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--clr-off-white, #f3f4f6);
    border: 1px solid var(--clr-border, #e5e7eb);
}
.layanan-infografis img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}
.layanan-infografis figcaption {
    padding: var(--sp-3) var(--sp-5);
    font-size: var(--fs-sm);
    color: var(--clr-text-secondary);
    line-height: 1.6;
    background: var(--clr-white);
    border-top: 1px solid var(--clr-border, #e5e7eb);
}

@media (prefers-reduced-motion: reduce) {
    .content-card .ib-list .ib-item { transition: none; }
    .content-card .ib-list .ib-item:hover { transform: none; }
}

/* â”€â”€ UserWay accessibility widget â€” force position to bottom-left â”€â”€â”€â”€ */
/* Targets all known container selectors UserWay uses across versions. */
#userwayAccessibilityIcon,
.userway_buttons_wrapper,
.uwy.userway_p1,
.uwy.userway_p2,
.uwy.userway_p3,
.uwy.userway_p4,
.uwy.userway_p5,
.uwy.userway_p6,
.uwy.userway_p7,
.uwy.userway_p8,
.uwy.userway_p9,
.uwy {
    left: 16px !important;
    right: auto !important;
    bottom: 16px !important;
    top: auto !important;
}

/* =========================================================
   PROGRAM UNGGULAN — combined card variants (Prioritas / Inovasi)
   ========================================================= */
.i2-programs-grid--4col {
    grid-template-columns: repeat(4, 1fr);
}
.i2-program-card--prioritas { border-left-color: transparent; }

/* Decorative SVG watermarks (peek-out at bottom-right corner).
   - Prioritas: graduation cap in blue
   - Inovasi: light bulb in gold
   Uses ::after (::before is the corner circle). Subtle opacity so text
   stays readable, but a bit more visible than a faint watermark. */
.i2-program-card--prioritas::after,
.i2-program-card--inovasi::after {
    content: '';
    position: absolute;
    bottom: -24px;
    right: -22px;
    width: 150px;
    height: 150px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    transform-origin: center;
    pointer-events: none;
    transition: opacity 0.3s ease, transform 0.4s ease;
    z-index: 0;
}

/* Prioritas — graduation cap (blue) */
.i2-program-card--prioritas::after {
    background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23067ac1'%3E%3Cpath d='M12 3L1 9l4 2.18v6L12 21l7-3.82v-6l2-1.09V17h2V9L12 3zm6.82 6L12 12.72 5.18 9 12 5.28 18.82 9zM17 16l-5 2.72-5-2.72v-3.73L12 15l5-2.73V16z'/%3E%3C/svg%3E");
    opacity: 0.10;
    transform: rotate(-14deg);
}
.i2-program-card--prioritas:hover::after {
    opacity: 0.18;
    transform: rotate(-8deg) scale(1.06);
}

/* Inovasi — light bulb (gold) */
.i2-program-card--inovasi::after {
    background-image: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23f9a703'%3E%3Cpath d='M9 21c0 .55.45 1 1 1h4c.55 0 1-.45 1-1v-1H9v1zm3-19C8.14 2 5 5.14 5 9c0 2.38 1.19 4.47 3 5.74V17c0 .55.45 1 1 1h6c.55 0 1-.45 1-1v-2.26c1.81-1.27 3-3.36 3-5.74 0-3.86-3.14-7-7-7z'/%3E%3C/svg%3E");
    opacity: 0.12;
    transform: rotate(12deg);
}
.i2-program-card--inovasi:hover::after {
    opacity: 0.20;
    transform: rotate(6deg) scale(1.06);
}

/* Make sure content sits above the watermark layer */
.i2-program-card > * { position: relative; z-index: 1; }

.i2-program-card--inovasi {
    background: linear-gradient(180deg, #fffaf0 0%, var(--clr-off-white) 100%);
}
.i2-program-card--inovasi::before {
    background: var(--clr-gold);
    opacity: 0.06;
}
.i2-program-card--inovasi .i2-program-num { color: var(--clr-gold); opacity: 0.22; }
.i2-program-card--inovasi:hover {
    border-left-color: var(--clr-gold);
    box-shadow: 0 12px 32px rgba(249,167,3,0.18);
}
.i2-program-card--inovasi .i2-program-arrow { color: #a06200; }
@media (max-width: 1200px) { .i2-programs-grid--4col { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 900px)  { .i2-programs-grid--4col { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .i2-programs-grid--4col { grid-template-columns: 1fr; } }

/* =========================================================
   JADWAL KEGIATAN — Calendar view (bulan berjalan) — WHITE
   ========================================================= */
.i4-jadwal {
    position: relative;
    background: var(--clr-white);
    overflow: hidden;
}
.i4-jadwal-bg {
    background:
        radial-gradient(circle at 15% 20%, rgba(6,122,193,0.07) 0%, transparent 45%),
        radial-gradient(circle at 85% 80%, rgba(249,167,3,0.05) 0%, transparent 40%),
        var(--clr-white);
}
.i4-jadwal-blob {
    position: absolute;
    width: 320px; height: 320px;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.45;
    z-index: 0;
    pointer-events: none;
    will-change: transform;
}
.i4-jadwal-blob-l { top: 10%; left: -80px;  background: radial-gradient(circle, rgba(6,122,193,0.35), transparent 70%); }
.i4-jadwal-blob-r { bottom: 5%; right: -100px; background: radial-gradient(circle, rgba(249,167,3,0.3), transparent 70%); }

.i4-cal-wrap {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--sp-6);
    align-items: start;
    background: var(--clr-white);
    border-radius: var(--radius-2xl);
    padding: var(--sp-6);
    box-shadow: 0 14px 50px rgba(6,122,193,0.08), 0 2px 8px rgba(0,0,0,0.04);
    border: 1px solid rgba(6,122,193,0.06);
    position: relative;
}
.i4-cal-header {
    grid-column: 1 / 2;
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    margin-bottom: var(--sp-2);
}
.i4-cal-dow {
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--clr-text-muted);
    text-align: center;
    padding: var(--sp-2) 0;
}
.i4-cal-dow.weekend { color: var(--clr-blue); }

.i4-cal-grid {
    grid-column: 1 / 2;
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 4px;
    min-width: 0;
}
.i4-cal-row      { display: contents; }
.i4-cal-calendar { display: contents; }
.i4-cal-cell {
    position: relative;
    min-height: 92px;
    min-width: 0;
    padding: 6px 8px 8px;
    background: #fafcff;
    border: 1px solid rgba(6,122,193,0.06);
    border-radius: var(--radius-md);
    transition: background 0.2s, border-color 0.2s, transform 0.2s, box-shadow 0.2s;
    display: flex; flex-direction: column;
    color: var(--clr-text-primary);
    overflow: hidden;
}
.i4-cal-cell.out-month { opacity: 0.35; background: transparent; border-color: transparent; }
.i4-cal-cell.weekend   { background: #f5f9fd; }
.i4-cal-cell.today {
    background: linear-gradient(135deg, var(--clr-blue) 0%, #1a6fab 100%);
    border-color: var(--clr-blue);
    color: #fff;
    box-shadow: 0 8px 24px rgba(6,122,193,0.35), inset 0 1px 0 rgba(255,255,255,0.2);
}
.i4-cal-cell.today .i4-cal-date { color: #fff; }
.i4-cal-cell.today .i4-cal-event { background: rgba(255,255,255,0.22); color: #fff; }
.i4-cal-cell.today .i4-cal-event-dot { background: var(--clr-gold); }
.i4-cal-cell.has-events { cursor: pointer; }
.i4-cal-cell.has-events:not(.today):hover {
    background: #fff;
    border-color: var(--clr-blue);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(6,122,193,0.15);
}
.i4-cal-date {
    font-size: 0.85rem;
    font-weight: 800;
    color: var(--clr-text-primary);
    line-height: 1;
    margin-bottom: 4px;
}
.i4-cal-events {
    display: flex; flex-direction: column; gap: 3px;
    overflow: hidden;
    min-width: 0;
}
.i4-cal-event {
    display: flex; align-items: center; gap: 4px;
    font-size: 0.65rem; line-height: 1.25;
    padding: 2px 4px;
    background: rgba(6,122,193,0.1);
    border-radius: 4px;
    color: var(--clr-blue);
    font-weight: 600;
    overflow: hidden;
    min-width: 0;
    max-width: 100%;
}
.i4-cal-event--inovasi {
    background: rgba(249,167,3,0.15);
    color: #a06200;
}
.i4-cal-event-dot {
    width: 5px; height: 5px;
    background: currentColor;
    border-radius: 50%;
    flex-shrink: 0;
    opacity: 0.85;
}
.i4-cal-event-title {
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    min-width: 0; flex: 1;
}
.i4-cal-more {
    font-size: 0.62rem;
    color: var(--clr-text-muted);
    font-weight: 600;
    padding: 0 4px;
}
.i4-cal-cell.today .i4-cal-more { color: rgba(255,255,255,0.85); }

/* Popover (hover/focus reveal) */
.i4-cal-pop {
    position: absolute;
    bottom: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%) translateY(6px);
    min-width: 280px; max-width: 340px;
    background: #fff;
    color: var(--clr-text-primary);
    border-radius: var(--radius-lg);
    box-shadow: 0 20px 50px rgba(0,0,0,0.22), 0 2px 8px rgba(0,0,0,0.08);
    padding: var(--sp-4);
    opacity: 0; pointer-events: none;
    transition: opacity 0.2s, transform 0.2s;
    z-index: 30;
    border: 1px solid rgba(6,122,193,0.1);
    cursor: default;
    text-align: left;
}
.i4-cal-pop-head {
    display: flex; justify-content: space-between; align-items: center;
    padding-bottom: var(--sp-2);
    margin-bottom: var(--sp-3);
    border-bottom: 1px solid rgba(6,122,193,0.1);
    gap: var(--sp-2);
}
.i4-cal-pop-head-date {
    font-size: 0.72rem; font-weight: 800;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--clr-blue);
}
.i4-cal-pop-close {
    width: 24px; height: 24px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(6,122,193,0.08);
    border: none;
    border-radius: 50%;
    color: var(--clr-text-secondary);
    cursor: pointer;
    font-size: 1rem; line-height: 1;
    flex-shrink: 0;
    transition: background 0.18s, color 0.18s, transform 0.15s;
}
.i4-cal-pop-close:hover {
    background: var(--clr-blue); color: #fff; transform: rotate(90deg);
}
.i4-cal-pop::after {
    content: ''; position: absolute;
    bottom: -6px; left: 50%; transform: translateX(-50%) rotate(45deg);
    width: 12px; height: 12px;
    background: #fff;
    border-right: 1px solid rgba(6,122,193,0.1);
    border-bottom: 1px solid rgba(6,122,193,0.1);
}
/* Open state — visibility only, transform handled per-cell-position below */
.i4-cal-cell.has-events.is-open .i4-cal-pop {
    opacity: 1; pointer-events: auto;
    z-index: 60;
}
.i4-cal-cell.has-events.is-open {
    z-index: 50;
    background: #fff;
    border-color: var(--clr-blue);
    box-shadow: 0 12px 32px rgba(6,122,193,0.22);
    overflow: visible;
}
/* Middle cells: popover centered above cell (default) */
.i4-cal-cell.has-events.is-open .i4-cal-pop { transform: translateX(-50%) translateY(0); }

/* Auto-shift popover near grid edges so it stays inside the calendar wrap.
   Higher specificity ":nth-child + .is-open + descendant" to override the middle rule. */
.i4-cal-cell:nth-child(7n+1) .i4-cal-pop,
.i4-cal-cell:nth-child(7n+2) .i4-cal-pop { left: 0; transform: translateX(0) translateY(6px); }
.i4-cal-cell:nth-child(7n+1).has-events.is-open .i4-cal-pop,
.i4-cal-cell:nth-child(7n+2).has-events.is-open .i4-cal-pop { transform: translateX(0) translateY(0); }
.i4-cal-cell:nth-child(7n+1) .i4-cal-pop::after,
.i4-cal-cell:nth-child(7n+2) .i4-cal-pop::after { left: 20px; transform: rotate(45deg); }

.i4-cal-cell:nth-child(7n) .i4-cal-pop,
.i4-cal-cell:nth-child(7n-1) .i4-cal-pop { left: auto; right: 0; transform: translateX(0) translateY(6px); }
.i4-cal-cell:nth-child(7n).has-events.is-open .i4-cal-pop,
.i4-cal-cell:nth-child(7n-1).has-events.is-open .i4-cal-pop { transform: translateX(0) translateY(0); }
.i4-cal-cell:nth-child(7n) .i4-cal-pop::after,
.i4-cal-cell:nth-child(7n-1) .i4-cal-pop::after { left: auto; right: 20px; transform: rotate(45deg); }
.i4-cal-pop-item + .i4-cal-pop-item {
    margin-top: var(--sp-3);
    padding-top: var(--sp-3);
    border-top: 1px dashed rgba(6,122,193,0.12);
}
.i4-cal-pop-time {
    font-size: 0.7rem; font-weight: 700;
    color: var(--clr-blue);
    text-transform: uppercase; letter-spacing: 0.04em;
    margin-bottom: 2px;
}
.i4-cal-pop-title { font-size: 0.85rem; font-weight: 700; color: var(--clr-text-primary); line-height: 1.35; }
.i4-cal-pop-loc, .i4-cal-pop-prog {
    font-size: 0.72rem; color: var(--clr-text-muted); margin-top: 4px; line-height: 1.4;
}
.i4-cal-pop-prog { color: var(--clr-blue); font-weight: 600; }

/* Upcoming sidebar list — light theme */
.i4-cal-upcoming {
    grid-column: 2 / 3; grid-row: 1 / 3;
    background: linear-gradient(180deg, #f8fbff 0%, #fff 100%);
    border-radius: var(--radius-xl);
    padding: var(--sp-4);
    border: 1px solid rgba(6,122,193,0.08);
    align-self: stretch;
}
.i4-cal-upcoming-head {
    display: flex; justify-content: space-between; align-items: center; gap: var(--sp-2);
    font-size: 0.72rem; font-weight: 800;
    text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--clr-blue);
    padding-bottom: var(--sp-3);
    margin-bottom: var(--sp-3);
    border-bottom: 1px solid rgba(6,122,193,0.1);
}
.i4-cal-upcoming-count {
    font-size: 0.65rem; font-weight: 700;
    padding: 2px 8px; border-radius: 999px;
    background: rgba(6,122,193,0.1);
    color: var(--clr-blue);
    letter-spacing: 0.04em;
}
.i4-cal-upcoming-list {
    display: flex; flex-direction: column; gap: var(--sp-2);
    max-height: 540px;
    overflow-y: auto;
    padding-right: var(--sp-1);
}
.i4-cal-upcoming-list::-webkit-scrollbar { width: 6px; }
.i4-cal-upcoming-list::-webkit-scrollbar-track { background: transparent; }
.i4-cal-upcoming-list::-webkit-scrollbar-thumb { background: rgba(6,122,193,0.2); border-radius: 3px; }
.i4-cal-upcoming-list::-webkit-scrollbar-thumb:hover { background: rgba(6,122,193,0.4); }
.i4-cal-up-item.is-past { opacity: 0.45; }
.i4-cal-up-item.is-past:hover { opacity: 0.7; }
.i4-cal-up-item {
    display: flex; gap: var(--sp-3);
    padding: var(--sp-3);
    border-radius: var(--radius-md);
    transition: background 0.2s, transform 0.2s;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}
.i4-cal-up-item:hover { background: rgba(6,122,193,0.05); transform: translateX(3px); }
.i4-cal-up-date {
    flex-shrink: 0;
    width: 48px;
    text-align: center;
    background: linear-gradient(135deg, var(--clr-blue) 0%, #1a6fab 100%);
    color: #fff;
    border-radius: var(--radius-md);
    padding: 6px 0;
    box-shadow: 0 4px 12px rgba(6,122,193,0.3);
}
.i4-cal-up-date--inovasi {
    background: linear-gradient(135deg, var(--clr-gold) 0%, #f0a800 100%);
    color: var(--clr-dark, #0f172a);
    box-shadow: 0 4px 12px rgba(249,167,3,0.3);
}
.i4-cal-up-day { font-size: 1.25rem; font-weight: 900; line-height: 1; }
.i4-cal-up-mon { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; opacity: 0.9; margin-top: 2px; }
.i4-cal-up-body { flex: 1; min-width: 0; }
.i4-cal-up-title {
    font-size: 0.85rem; font-weight: 700; color: var(--clr-text-primary);
    line-height: 1.35; margin-bottom: 4px;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.i4-cal-up-meta { font-size: 0.7rem; color: var(--clr-text-muted); display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.i4-cal-up-range {
    display: inline-flex; align-items: center;
    background: rgba(6,122,193,0.1);
    color: var(--clr-blue);
    padding: 1px 6px; border-radius: 4px;
    font-weight: 700; letter-spacing: 0.02em;
}
.i4-cal-empty {
    text-align: center; padding: var(--sp-8); color: var(--clr-text-muted);
    grid-column: 1 / -1;
}

/* Calendar responsive */
@media (max-width: 1100px) {
    .i4-cal-wrap { grid-template-columns: 1fr; }
    .i4-cal-upcoming { grid-column: 1 / 2; grid-row: auto; }
    .i4-cal-header, .i4-cal-grid { grid-column: 1 / 2; }
}
@media (max-width: 768px) {
    .i4-cal-wrap { padding: var(--sp-3); border-radius: var(--radius-xl); }
    .i4-cal-cell { min-height: 64px; padding: 4px; }
    .i4-cal-date { font-size: 0.72rem; }
    .i4-cal-event { font-size: 0.58rem; padding: 1px 3px; }
    .i4-cal-event-title { display: none; }
    .i4-cal-event { justify-content: center; }
    .i4-cal-more { font-size: 0.55rem; text-align: center; }
    .i4-cal-pop { min-width: 200px; max-width: 260px; }
}
@media (max-width: 480px) {
    .i4-cal-cell { min-height: 52px; }
    .i4-cal-dow { font-size: 0.6rem; padding: var(--sp-1) 0; }
}

/* =========================================================
   LAYANAN UTAMA — Horizontal photo side-scroll
   ========================================================= */
.i4-layanan {
    position: relative;
    background: var(--clr-white);
    overflow: hidden;
}
.i4-layanan-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: var(--sp-6);
    margin-bottom: var(--sp-10);
}
.i4-layanan-header .section-title { margin-bottom: var(--sp-2); }
.i4-layanan-nav {
    display: flex;
    gap: var(--sp-2);
    flex-shrink: 0;
}
.i4-layanan-arrow {
    width: 48px; height: 48px;
    border-radius: 50%;
    border: 1px solid rgba(6,122,193,0.18);
    background: var(--clr-white);
    color: var(--clr-blue);
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(6,122,193,0.1);
    transition: background 0.2s, color 0.2s, transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.i4-layanan-arrow:hover:not(:disabled) {
    background: var(--clr-blue);
    color: #fff;
    transform: scale(1.08);
    box-shadow: 0 8px 22px rgba(6,122,193,0.35);
    border-color: var(--clr-blue);
}
.i4-layanan-arrow:disabled { opacity: 0.35; cursor: not-allowed; }

/* Scroller — horizontal w/ snap, hide scrollbar */
.i4-layanan-scroller {
    position: relative;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: var(--sp-6) 0 var(--sp-8);
    margin: 0 calc(var(--sp-6) * -1);
}
.i4-layanan-scroller::-webkit-scrollbar { display: none; }
.i4-layanan-track {
    display: flex;
    gap: var(--sp-6);
    padding: 0 calc((100vw - min(1140px, 100vw)) / 2 + var(--sp-6));
    width: max-content;
}
@media (max-width: 1200px) {
    .i4-layanan-track { padding-left: var(--sp-6); padding-right: var(--sp-6); }
}

/* Card — portrait aspect 3:4, image-first */
.i4-layanan-card {
    flex-shrink: 0;
    width: 380px;
    scroll-snap-align: start;
    text-decoration: none;
    color: inherit;
    transition: transform 0.4s cubic-bezier(.22,.68,0,1.2);
    will-change: transform;
}
.i4-layanan-card:hover { transform: translateY(-8px); }
.i4-layanan-card-media {
    position: relative;
    aspect-ratio: 3 / 4;
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: 0 14px 40px rgba(6,122,193,0.12), 0 2px 8px rgba(0,0,0,0.05);
    transition: box-shadow 0.3s;
    isolation: isolate;
}
.i4-layanan-card:hover .i4-layanan-card-media {
    box-shadow: 0 24px 60px rgba(6,122,193,0.25), 0 4px 16px rgba(0,0,0,0.1);
}
.i4-layanan-card-img {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.8s cubic-bezier(.22,.68,0,1.2);
    z-index: 0;
}
.i4-layanan-card:hover .i4-layanan-card-img { transform: scale(1.08); }
.i4-layanan-card-placeholder {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    z-index: 0;
}
.i4-layanan-card.i4-pal-blue   .i4-layanan-card-placeholder { background: linear-gradient(135deg, #067ac1 0%, #033a5d 100%); }
.i4-layanan-card.i4-pal-gold   .i4-layanan-card-placeholder { background: linear-gradient(135deg, #f9a703 0%, #d68800 100%); }
.i4-layanan-card.i4-pal-teal   .i4-layanan-card-placeholder { background: linear-gradient(135deg, #0d9488 0%, #064e4a 100%); }
.i4-layanan-card.i4-pal-purple .i4-layanan-card-placeholder { background: linear-gradient(135deg, #7c3aed 0%, #4c1d95 100%); }
.i4-layanan-card.i4-pal-rose   .i4-layanan-card-placeholder { background: linear-gradient(135deg, #e11d48 0%, #881337 100%); }
.i4-layanan-card.i4-pal-indigo .i4-layanan-card-placeholder { background: linear-gradient(135deg, #4f46e5 0%, #1e1b4b 100%); }
.i4-layanan-card-placeholder svg {
    width: 96px; height: 96px;
    color: rgba(255,255,255,0.85);
    stroke-width: 1.4;
    filter: drop-shadow(0 4px 12px rgba(0,0,0,0.25));
}

/* Gradient shade — keeps text readable over any photo */
.i4-layanan-card-shade {
    position: absolute; inset: 0;
    background: linear-gradient(to top,
        rgba(0,0,0,0.78) 0%,
        rgba(0,0,0,0.45) 35%,
        rgba(0,0,0,0.12) 60%,
        transparent 100%);
    z-index: 1;
}

/* Floating big number — top right */
.i4-layanan-card-num {
    position: absolute;
    top: var(--sp-4); right: var(--sp-4);
    z-index: 2;
    font-size: 1.4rem;
    font-weight: 900;
    color: #fff;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,0.18);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,0.3);
    letter-spacing: -0.02em;
    line-height: 1;
}

/* Bottom content — title + desc + cta */
.i4-layanan-card-content {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    z-index: 2;
    padding: var(--sp-6) var(--sp-5) var(--sp-5);
    color: #fff;
    display: flex; flex-direction: column;
    gap: var(--sp-2);
}
.i4-layanan-card-title {
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    line-height: 1.25;
    text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.i4-layanan-card-desc {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.85);
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-shadow: 0 1px 6px rgba(0,0,0,0.3);
    opacity: 0.95;
}
.i4-layanan-card-cta {
    display: inline-flex; align-items: center; gap: 6px;
    margin-top: var(--sp-2);
    padding: 8px 14px;
    background: rgba(255,255,255,0.95);
    color: var(--clr-blue);
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    width: fit-content;
    box-shadow: 0 4px 14px rgba(0,0,0,0.2);
    transition: gap 0.25s, background 0.2s, color 0.2s;
}
.i4-layanan-card:hover .i4-layanan-card-cta {
    gap: 10px;
    background: var(--clr-gold);
    color: var(--clr-dark, #0f172a);
}
.i4-layanan-card.i4-pal-gold:hover .i4-layanan-card-cta {
    background: var(--clr-blue);
    color: #fff;
}

/* Edge fade masks removed — caused random card cut-off depending on scroll/viewport */
.i4-layanan-fade { display: none; }

/* Progress bar — shows scroll position */
.i4-layanan-progress {
    height: 3px;
    background: rgba(6,122,193,0.1);
    border-radius: 2px;
    overflow: hidden;
    margin-top: var(--sp-4);
    max-width: 280px;
}
.i4-layanan-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--clr-blue), var(--clr-gold));
    width: 0%;
    border-radius: 2px;
    transition: width 0.2s ease-out;
}

/* Responsive */
@media (max-width: 768px) {
    .i4-layanan-header { flex-direction: column; align-items: flex-start; }
    .i4-layanan-card { width: 300px; }
    .i4-layanan-card-title { font-size: 1.1rem; }
    .i4-layanan-card-num { font-size: 1.1rem; padding: 4px 10px; }
    .i4-layanan-fade { width: 32px; }
}
@media (max-width: 480px) {
    .i4-layanan-card { width: 260px; }
    .i4-layanan-card-content { padding: var(--sp-4); }
    .i4-layanan-arrow { width: 40px; height: 40px; }
}

/* =========================================================
   LAYANAN UTAMA — Scrollytelling (sticky visual + steps) [LEGACY]
   ========================================================= */
.i4-scrolly { position: relative; background: var(--clr-off-white, #f7fafc); overflow: hidden; }
.i4-scrolly-wrap {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: var(--sp-10);
    align-items: start;
}

/* Sticky visual stage */
.i4-scrolly-visual {
    position: sticky;
    top: calc(var(--nav-height, 80px) + var(--sp-6));
    height: 70vh;
    min-height: 480px;
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
}
.i4-scrolly-stage {
    position: relative;
    flex: 1;
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.05);
}
.i4-scrolly-frame {
    position: absolute; inset: 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    color: #fff;
    text-align: center;
    opacity: 0;
    transform: scale(1.05);
    transition: opacity 0.6s cubic-bezier(.4,0,.2,1), transform 0.6s cubic-bezier(.4,0,.2,1);
    padding: var(--sp-8);
}
.i4-scrolly-frame.is-active { opacity: 1; transform: scale(1); z-index: 2; }

/* Palette backgrounds for frames */
.i4-scrolly-frame.i4-pal-blue   .i4-scrolly-frame-bg { background: linear-gradient(135deg, #067ac1 0%, #033a5d 100%); }
.i4-scrolly-frame.i4-pal-gold   .i4-scrolly-frame-bg { background: linear-gradient(135deg, #f9a703 0%, #d68800 100%); }
.i4-scrolly-frame.i4-pal-teal   .i4-scrolly-frame-bg { background: linear-gradient(135deg, #0d9488 0%, #064e4a 100%); }
.i4-scrolly-frame.i4-pal-purple .i4-scrolly-frame-bg { background: linear-gradient(135deg, #7c3aed 0%, #4c1d95 100%); }
.i4-scrolly-frame.i4-pal-rose   .i4-scrolly-frame-bg { background: linear-gradient(135deg, #e11d48 0%, #881337 100%); }
.i4-scrolly-frame.i4-pal-indigo .i4-scrolly-frame-bg { background: linear-gradient(135deg, #4f46e5 0%, #1e1b4b 100%); }
.i4-scrolly-frame-bg {
    position: absolute; inset: 0; z-index: 0;
}
.i4-scrolly-frame-bg::after {
    content: ''; position: absolute; inset: 0;
    background:
        radial-gradient(circle at 25% 25%, rgba(255,255,255,0.18) 0%, transparent 50%),
        radial-gradient(circle at 75% 75%, rgba(255,255,255,0.10) 0%, transparent 45%);
}
.i4-scrolly-frame-grid {
    position: absolute; inset: 0; z-index: 1; pointer-events: none;
    background-image:
        linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 30%, transparent 90%);
    -webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 30%, transparent 90%);
}
.i4-scrolly-frame-num {
    position: absolute; top: var(--sp-6); right: var(--sp-6); z-index: 2;
    font-size: 5rem; font-weight: 900;
    color: rgba(255,255,255,0.15);
    line-height: 1; letter-spacing: -0.04em;
}
.i4-scrolly-frame-icon {
    position: relative; z-index: 2;
    width: 140px; height: 140px;
    border-radius: var(--radius-2xl);
    background: rgba(255,255,255,0.15);
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.25);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: var(--sp-6);
    color: #fff;
    box-shadow: 0 10px 30px rgba(0,0,0,0.2);
}
.i4-scrolly-frame-icon svg { width: 64px; height: 64px; stroke-width: 1.6; }
.i4-scrolly-frame-label {
    position: relative; z-index: 2;
    font-size: clamp(1.5rem, 2.4vw, 2.2rem);
    font-weight: 900;
    text-shadow: 0 2px 12px rgba(0,0,0,0.3);
    letter-spacing: -0.01em;
    max-width: 80%;
}

/* Progress bar */
.i4-scrolly-progress {
    height: 4px; background: rgba(6,122,193,0.1);
    border-radius: 2px; overflow: hidden;
}
.i4-scrolly-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--clr-blue), var(--clr-gold));
    width: 0;
    transition: width 0.4s cubic-bezier(.4,0,.2,1);
    border-radius: 2px;
}

/* Steps list (right column) */
.i4-scrolly-steps {
    display: flex; flex-direction: column;
    gap: 28vh;
    padding: 12vh 0;
}
.i4-scrolly-step {
    position: relative;
    display: flex; gap: var(--sp-5);
    padding: var(--sp-6);
    background: var(--clr-white);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(0,0,0,0.06);
    box-shadow: 0 6px 24px rgba(0,0,0,0.04);
    text-decoration: none; color: inherit;
    transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
    scroll-margin-top: calc(var(--nav-height, 80px) + var(--sp-6));
    opacity: 0.4;
    transform: translateY(20px);
}
.i4-scrolly-step.is-active {
    opacity: 1;
    transform: translateY(0);
    box-shadow: 0 14px 40px rgba(6,122,193,0.12);
    border-color: rgba(6,122,193,0.18);
}
.i4-scrolly-step:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 48px rgba(6,122,193,0.18);
}
.i4-scrolly-step-num {
    flex-shrink: 0;
    width: 56px; height: 56px;
    border-radius: var(--radius-lg);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; font-weight: 900;
    color: #fff;
    transition: transform 0.3s, box-shadow 0.3s;
}
.i4-scrolly-step.is-active .i4-scrolly-step-num { transform: scale(1.05); }
.i4-scrolly-step.i4-pal-blue   .i4-scrolly-step-num { background: linear-gradient(135deg,#067ac1,#033a5d); box-shadow: 0 6px 18px rgba(6,122,193,0.45); }
.i4-scrolly-step.i4-pal-gold   .i4-scrolly-step-num { background: linear-gradient(135deg,#f9a703,#d68800); box-shadow: 0 6px 18px rgba(249,167,3,0.45); color: var(--clr-dark, #0f172a); }
.i4-scrolly-step.i4-pal-teal   .i4-scrolly-step-num { background: linear-gradient(135deg,#0d9488,#064e4a); box-shadow: 0 6px 18px rgba(13,148,136,0.45); }
.i4-scrolly-step.i4-pal-purple .i4-scrolly-step-num { background: linear-gradient(135deg,#7c3aed,#4c1d95); box-shadow: 0 6px 18px rgba(124,58,237,0.45); }
.i4-scrolly-step.i4-pal-rose   .i4-scrolly-step-num { background: linear-gradient(135deg,#e11d48,#881337); box-shadow: 0 6px 18px rgba(225,29,72,0.45); }
.i4-scrolly-step.i4-pal-indigo .i4-scrolly-step-num { background: linear-gradient(135deg,#4f46e5,#1e1b4b); box-shadow: 0 6px 18px rgba(79,70,229,0.45); }
.i4-scrolly-step-body { flex: 1; min-width: 0; }
.i4-scrolly-step-title {
    font-size: 1.35rem; font-weight: 800;
    color: var(--clr-text-primary);
    margin-bottom: var(--sp-2);
    letter-spacing: -0.01em;
}
.i4-scrolly-step-desc {
    font-size: 0.95rem;
    color: var(--clr-text-secondary);
    line-height: 1.65;
    margin-bottom: var(--sp-4);
}
.i4-scrolly-step-cta {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 0.85rem; font-weight: 700;
    color: var(--clr-blue);
    transition: gap 0.2s;
}
.i4-scrolly-step:hover .i4-scrolly-step-cta { gap: 12px; }

/* Responsive — stack on tablet/mobile, kill sticky */
@media (max-width: 900px) {
    .i4-scrolly-wrap { grid-template-columns: 1fr; gap: var(--sp-6); }
    .i4-scrolly-visual { position: static; height: 320px; min-height: 0; }
    .i4-scrolly-steps { gap: var(--sp-5); padding: 0; }
    .i4-scrolly-step { opacity: 1; transform: none; }
    .i4-scrolly-frame-icon { width: 100px; height: 100px; }
    .i4-scrolly-frame-icon svg { width: 48px; height: 48px; }
    .i4-scrolly-frame-num { font-size: 3.5rem; }
}
@media (max-width: 540px) {
    .i4-scrolly-step { flex-direction: column; padding: var(--sp-5); }
    .i4-scrolly-step-num { width: 44px; height: 44px; font-size: 1.1rem; }
    .i4-scrolly-step-title { font-size: 1.15rem; }
}

/* =========================================================
   HOME INDEX — visual overhaul (moved from Views/Home/Index.cshtml)
   ========================================================= */
.i4-section { padding: 5.5rem 0; }
.i4-section-inner { padding: 0 1.5rem; }

.i4-grad-text {
  background: linear-gradient(110deg, var(--clr-blue) 20%, var(--clr-gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-title .text-gradient {
  background: linear-gradient(110deg, var(--clr-blue) 0%, #4da6ff 60%, var(--clr-gold) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

.badge-ticker-section {
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
}

.i2-program-card {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .55s cubic-bezier(.22,.68,0,1.2), transform .55s cubic-bezier(.22,.68,0,1.2),
              box-shadow .25s ease, border-color .25s ease;
}
.i2-program-card.i4-card-visible { opacity: 1; transform: translateY(0); }
.i2-program-card:hover {
  box-shadow: 0 12px 40px rgba(6, 122, 193, 0.15), 0 2px 8px rgba(0,0,0,0.06);
  border-color: rgba(6, 122, 193, 0.25);
  transform: translateY(-4px);
}

.i4-inovasi-card {
  opacity: 0;
  transform: translateY(32px) scale(.97);
  transition: opacity .5s cubic-bezier(.22,.68,0,1.2), transform .5s cubic-bezier(.22,.68,0,1.2),
              box-shadow .28s ease;
}
.i4-inovasi-card.i4-card-visible { opacity: 1; transform: translateY(0) scale(1); }
.i4-inovasi-card:hover {
  box-shadow: 0 20px 60px rgba(0,0,0,0.35), 0 0 0 1px rgba(var(--clr-gold-rgb, 212,175,55),.2),
              0 0 40px rgba(212,175,55,0.12);
  transform: translateY(-6px) scale(1.01);
}

.i4-service-card {
  --mx: 50%; --my: 50%;
  position: relative; overflow: hidden;
  transition: transform .3s cubic-bezier(.22,.68,0,1.2), box-shadow .3s ease, border-color .3s ease;
}
.i4-service-card::before {
  content: '';
  position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background: radial-gradient(260px circle at var(--mx) var(--my), rgba(6,122,193,0.13) 0%, transparent 70%);
  opacity: 0;
  transition: opacity .3s ease;
}
.i4-service-card:hover::before { opacity: 1; }
.i4-service-card:hover {
  transform: translateY(-5px) scale(1.015);
  box-shadow: 0 18px 48px rgba(6,122,193,0.18), 0 2px 10px rgba(0,0,0,0.06);
  border-color: rgba(6,122,193,0.3);
}

.i4-bento-grid { display:grid; grid-template-columns:1.35fr 1fr; gap:1.5rem; margin-top:3rem; align-items:stretch; }
.i4-bento-left {
  background:var(--clr-white); border-radius:1.75rem; overflow:hidden;
  border:1px solid rgba(0,0,0,.05); display:flex; flex-direction:column;
  box-shadow:0 4px 20px rgba(0,0,0,.04);
  transition:box-shadow .28s ease, transform .28s ease;
}
.i4-bento-left:hover { box-shadow:0 16px 48px rgba(6,122,193,.14); transform:translateY(-4px); }
.i4-bento-right { display:flex; flex-direction:column; gap:1.5rem; }
.i4-bento-panel {
  flex:1; background:var(--clr-white); border-radius:1.5rem; overflow:hidden;
  border:1px solid rgba(0,0,0,.05); display:flex; flex-direction:column;
  box-shadow:0 4px 20px rgba(0,0,0,.04);
  transition:box-shadow .28s ease, transform .28s ease;
  position:relative;
}
.i4-bento-panel::before {
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--clr-blue);
}
.i4-bento-panel--gold::before { background:linear-gradient(90deg,var(--clr-gold) 0%,#f0a800 100%); }
.i4-bento-panel--teal::before { background:linear-gradient(90deg,#0d9488 0%,#14b8a6 100%); }
.i4-bento-panel:hover { box-shadow:0 12px 40px rgba(6,122,193,.12); transform:translateY(-3px); }

.i4-bento-hero {
  display:block; position:relative; height:480px; overflow:hidden; flex-shrink:0; text-decoration:none;
}
.i4-bento-hero img { width:100%; height:100%; object-fit:cover; object-position:center; transition:transform .9s cubic-bezier(.16,1,.3,1); }
.i4-bento-hero:hover img { transform:scale(1.06); }
.i4-bento-hero-ph {
  width:100%; height:100%;
  background:linear-gradient(135deg,var(--clr-blue) 0%,#1a6fab 50%,var(--clr-blue-deeper,#053060) 100%);
}
.i4-bento-hero-shade {
  position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(to top, rgba(0,0,0,.88) 0%, rgba(0,0,0,.55) 35%, rgba(0,0,0,.15) 65%, transparent 100%),
    linear-gradient(135deg, rgba(6,122,193,.18) 0%, transparent 55%);
}
.i4-bento-hero-body {
  position:absolute; inset:auto 0 0 0; padding:1.75rem 2rem 1.85rem;
  display:flex; flex-direction:column; gap:.7rem; z-index:1;
}
.i4-bento-hero-meta { display:flex; align-items:center; gap:.75rem; flex-wrap:wrap; }
.i4-bento-hero-date {
  font-size:.72rem; font-weight:600; color:rgba(255,255,255,.78);
  letter-spacing:.02em;
}
.i4-bento-hero-title {
  font-size:1.55rem; font-weight:800; color:#fff; line-height:1.25;
  letter-spacing:-.01em;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
  text-shadow:0 2px 12px rgba(0,0,0,.35);
}
.i4-bento-hero-excerpt {
  font-size:.88rem; color:rgba(255,255,255,.78); line-height:1.55; margin:0;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  text-shadow:0 1px 6px rgba(0,0,0,.3);
}
.i4-bento-hero-cta {
  display:inline-flex; align-items:center; gap:.4rem;
  font-size:.78rem; font-weight:700; color:var(--clr-gold-light, #fbbf24);
  text-transform:uppercase; letter-spacing:.08em;
  margin-top:.35rem;
  transition:gap .25s ease, color .2s ease;
}
.i4-bento-hero:hover .i4-bento-hero-cta { gap:.7rem; color:#fff; }
.i4-bento-hero-cta svg { transition:transform .25s ease; }
.i4-bento-hero:hover .i4-bento-hero-cta svg { transform:translateX(3px); }

.i4-tri-head {
  display:flex; justify-content:space-between; align-items:center;
  padding:1.15rem 1.5rem .95rem; border-bottom:1px solid rgba(0,0,0,.06);
}
.i4-tri-label      { font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.14em; color:var(--clr-blue); display:inline-flex; align-items:center; gap:.5rem; }
.i4-tri-label::before { content:""; width:14px; height:2px; background:currentColor; display:inline-block; border-radius:2px; }
.i4-tri-label.gold { color:var(--clr-gold); }
.i4-tri-label.teal { color:#0d9488; }
.i4-tri-more       { font-size:.7rem; font-weight:700; color:var(--clr-text-secondary); text-decoration:none; opacity:.7; transition:opacity .2s, color .2s; }
.i4-tri-more:hover { opacity:1; color:var(--clr-blue); }
.i4-tri-badge      {
  display:inline-flex; align-items:center; gap:.35rem;
  font-size:.6rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em;
  padding:.32em .75em; border-radius:999px;
  background:linear-gradient(135deg,var(--clr-blue) 0%,#1a6fab 100%); color:#fff;
  box-shadow:0 4px 12px rgba(6,122,193,.35);
  width:fit-content;
}
.i4-tri-badge.gold { background:linear-gradient(135deg,var(--clr-gold) 0%,#f0a800 100%); color:#3a2000; box-shadow:0 4px 12px rgba(249,167,3,.35); }
.i4-tri-badge.teal { background:linear-gradient(135deg,#0d9488 0%,#14b8a6 100%); color:#fff; box-shadow:0 4px 12px rgba(13,148,136,.35); }
.i4-tri-list       { display:flex; flex-direction:column; flex:1; padding:.3rem 0; }
.i4-tri-item {
  display:flex; flex-direction:column; gap:.25rem;
  padding:.95rem 1.5rem; border-bottom:1px solid rgba(0,0,0,.04);
  text-decoration:none; transition:background .2s ease, padding-left .2s ease;
}
.i4-tri-item:last-child  { border-bottom:none; }
.i4-tri-item:hover       { background:rgba(6,122,193,.03); padding-left:1.7rem; }
.i4-tri-item-date        { font-size:.65rem; color:var(--clr-text-muted); font-weight:600; text-transform:uppercase; letter-spacing:.05em; }
.i4-tri-item-title {
  font-size:.92rem; font-weight:700; color:var(--clr-heading); line-height:1.4;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  transition:color .18s ease;
}
.i4-tri-item:hover .i4-tri-item-title { color:var(--clr-blue); }
.i4-tri-empty { padding:1.5rem 1.5rem; font-size:.82rem; color:var(--clr-text-muted); text-align:center; }

.i4-tri-item--thumb  { flex-direction:row; align-items:center; gap:.95rem; }
.i4-tri-thumb        { width:84px; height:84px; min-width:84px; border-radius:.7rem; object-fit:cover; flex-shrink:0; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.i4-tri-thumb--ph    { background:linear-gradient(135deg,rgba(6,122,193,.18) 0%,rgba(6,122,193,.05) 100%); }
.i4-tri-thumb--gold  { background:linear-gradient(135deg,rgba(249,167,3,.22) 0%,rgba(249,167,3,.06) 100%); }
.i4-tri-thumb--teal  { background:linear-gradient(135deg,rgba(13,148,136,.22) 0%,rgba(13,148,136,.06) 100%); }
.i4-tri-item-body    { flex:1; display:flex; flex-direction:column; gap:.28rem; min-width:0; }

@media (max-width:900px)  {
  .i4-bento-grid { grid-template-columns:1fr; }
  .i4-bento-hero { height:380px; }
  .i4-bento-hero-title { font-size:1.3rem; }
}
@media (max-width:576px)  {
  .i4-bento-grid { gap:1rem; }
  .i4-bento-hero { height:280px; }
  .i4-bento-hero-body { padding:1.25rem 1.35rem; }
  .i4-bento-hero-title { font-size:1.1rem; }
  .i4-tri-thumb { width:68px; height:68px; min-width:68px; }
}

.i4-about-feat {
  opacity: 0; transform: translateX(-16px);
  transition: opacity .5s ease, transform .5s ease;
}
.i4-about-feat.i4-feat-visible { opacity: 1; transform: translateX(0); }

@keyframes i4CardRingPulse {
  0%, 100% { transform: scale(1);   opacity: .18; }
  50%       { transform: scale(1.08); opacity: .32; }
}
.i4-hero-card-ring {
  animation: i4CardRingPulse 3.5s ease-in-out infinite;
}

@keyframes i4CueBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}
.i4-scroll-cue { animation: i4CueBounce 2.2s ease-in-out infinite; }

.section-label {
  letter-spacing: .12em;
  font-weight: 700;
}

.i4-contact-card {
  transition: box-shadow .3s ease, transform .3s ease;
}
.i4-contact-card:hover {
  box-shadow: 0 20px 56px rgba(6,122,193,0.14), 0 2px 10px rgba(0,0,0,0.06);
  transform: translateY(-3px);
}

.i4-conn-dot {
  box-shadow: 0 0 12px 4px rgba(6,122,193,0.4);
}

@media (max-width: 768px) {
  .i4-section { padding: 3.5rem 0; }
  .i4-section-inner { padding: 0 1rem; }
}
@media (max-width: 480px) {
  .i4-section { padding: 2.5rem 0; }
}

/* =========================================================
   HOME INDEX — utility classes for previously-inline styles
   ========================================================= */
.h-full              { height: 100%; }
.h-full-rel          { height: 100%; position: relative; }
.pos-rel-z2          { position: relative; z-index: 2; }
.pos-rel-z5          { position: relative; z-index: 5; }
.swp-cover           { position: absolute; inset: 0; width: 100%; height: 100%; }
.swp-pag-low         { bottom: 2.5rem; }
.grid-col-full       { grid-column: 1 / -1; }
.mw-540              { max-width: 540px; }
.mw-560              { max-width: 560px; }
.mb-04               { margin-bottom: 0.4rem; }
.mb-sp8              { margin-bottom: var(--sp-8); }
.mt-sp8              { margin-top: var(--sp-8); }
.mt-sp8-flex-gap     { margin-top: var(--sp-8); display: flex; gap: 0.75rem; }
.hero-actions-mt     { margin: var(--sp-8) 0 0; }
.btn-no-shrink-start { flex-shrink: 0; align-self: flex-start; }
.no-link-style       { color: inherit; text-decoration: none; }

/* Section header text variants */
.section-title-white-mb3 { color: #fff; margin-bottom: var(--sp-3); }
.section-subtitle-dark   { color: rgba(255,255,255,0.55); font-size: var(--fs-md); max-width: 480px; margin: 0 auto; line-height: var(--lh-relaxed); }
.layanan-header-sub      { color: var(--clr-text-secondary); font-size: var(--fs-md); max-width: 560px; line-height: var(--lh-relaxed); margin: var(--sp-3) 0 0; }
.about-text-block        { font-size: var(--fs-md); color: var(--clr-text-secondary); line-height: var(--lh-relaxed); margin-bottom: var(--sp-8); }
.about-feat-eyebrow      { font-size: var(--fs-xs); color: rgba(255,255,255,0.35); font-weight: 600; text-transform: uppercase; letter-spacing: .08em; }

/* Hero overlays (over background image) */
.hero-overlay-vert  { position: absolute; inset: 0; z-index: 1; pointer-events: none;
                      background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.55) 60%, rgba(0,0,0,0.7) 100%); }
.hero-overlay-horiz { position: absolute; inset: 0; z-index: 1; pointer-events: none;
                      background: linear-gradient(90deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.25) 45%, rgba(0,0,0,0) 75%); }

/* Dynamic hero bg image — use CSS custom prop to pass URL inline (only var passed) */
.hero-bg-dynamic { background-size: cover; background-position: center; background-image: var(--hero-bg); }

/* =========================================================
   DOC VIEWER MODAL (fullscreen iframe — from _Layout.cshtml)
   ========================================================= */
.doc-viewer-overlay {
    display: none;
    position: fixed; inset: 0;
    z-index: 99999;
    background: #000;
    flex-direction: column;
}
.doc-viewer-overlay.is-open { display: flex; }
.doc-viewer-bar {
    display: flex; align-items: center; justify-content: space-between;
    background: #0f172a;
    padding: 0.5rem 1rem;
    flex-shrink: 0;
    min-height: 44px;
}
.doc-viewer-title {
    color: #fff;
    font-size: 0.875rem;
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: calc(100% - 80px);
}
.doc-viewer-close {
    display: flex; align-items: center; gap: 0.375rem;
    background: #ef4444; color: #fff;
    border: none; border-radius: 6px;
    padding: 0.375rem 0.75rem;
    font-size: 0.8rem; font-weight: 600;
    cursor: pointer; flex-shrink: 0;
}
.doc-viewer-frame {
    flex: 1;
    width: 100%; height: 100%;
    border: none;
    display: block;
}

.mr-2px      { margin-right: 2px; }
.va-neg-2    { vertical-align: -2px; }

/* =========================================================
   AUTO-EXTRACTED inline styles (from cshtml refactor)
   ========================================================= */
.sx-2efd6432 { color:inherit;text-decoration:none; }
.sx-ec581898 { color:inherit;text-decoration:underline; }
.sx-b202c6d4 { cursor:pointer; }
.sx-58aba575 { cursor:pointer; }
.sx-30335f9b { display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap; }
.sx-da4ef98c { display:flex;align-items:center;justify-content:space-between; }
.sx-de8764ee { display:flex;align-items:flex-end;gap:4px;height:140px; }
.sx-64b8a6e5 { display:flex;flex-direction:column;align-items:center;flex-shrink:0; }
.sx-a48e7829 { display:flex;gap:0.5rem;flex-shrink:0; }
.sx-cb458930 { display:none; }
.sx-93b8ea5b { display:none; }
.sx-7792ed5d { display:none;margin-bottom:0.75rem; }
.sx-ea5d526b { flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%; }
.sx-5b214b83 { flex-shrink:0; }
.sx-8ec848c3 { font-size:0.85rem;font-weight:500;white-space:nowrap; }
.sx-4f9e4083 { font-size:1.25rem;letter-spacing:0.3rem;text-align:center;font-weight:600; }
.sx-8b685211 { font-size:11px; }
.sx-b84c7dfa { font-size:13px; }
.sx-6889ac7e { font-size:1rem;letter-spacing:0.1em;background:#f1f5f9;padding:8px 12px;border-radius:6px;display:block;word-break:break-all; }
.sx-cf44b5d4 { font-size:2.5rem; }
.sx-0d4cabcb { font-size:24px;line-height:1; }
.sx-7a7a693f { font-size:28px; }
.sx-ba2c5c3e { font-size:2rem; }
.sx-6d8d6153 { font-size:9px; }
.sx-7a33f644 { height:110px; overflow:hidden; cursor:pointer; }
.sx-a900300d { height:70px; }
.sx-46dcee64 { margin:0; }
.sx-4d6765ad { margin:0;flex:1; }
.sx-fa0ce9ce { margin:0;text-align:center; }
.sx-a2d48c76 { margin-bottom:0; }
.sx-da472840 { margin-left:6px; }
.sx-487b71ac { margin-right:6px; }
.sx-d7200813 { max-width:100%; }
.sx-5b7adece { max-width:100%;height:auto; }
.sx-8c92abea { max-width:120px; }
.sx-8ddd4566 { max-width:160px; }
.sx-74286440 { max-width:180px; }
.sx-015ccf91 { max-width:280px; }
.sx-28991212 { max-width:280px; }
.sx-4d14681b { max-width:300px; }
.sx-f758c5d0 { max-width:320px; }
.sx-284b8423 { max-width:340px; }
.sx-ae18a06a { max-width:420px; }
.sx-498da9fa { max-width:480px; }
.sx-6e9510a9 { max-width:480px;opacity:.55;cursor:not-allowed; }
.sx-ad5ca10a { min-width:0; }
.sx-b9fb75dc { min-width:260px; }
.sx-9aec2fee { padding:12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:inline-block; }
.sx-a5c6f7bc { padding:2px 8px;font-size:11px; }
.sx-9e27bf31 { position:absolute;inset:0;background-image:radial-gradient(circle at 80% 20%,rgba(249,167,3,0.15) 0%,transparent 50%); }
.sx-4bfcc11a { position:absolute;inset:0;background-image:radial-gradient(circle at 80% 50%,rgba(249,167,3,0.1) 0%,transparent 50%); }
.sx-2b79920e { position:relative;z-index:1; }
.sx-cb751ed4 { position:relative;z-index:2; }
.sx-9c33ea5e { width:0%; }
.sx-c4df71c2 { width:100%;border-radius:6px;max-height:240px;object-fit:cover; }
.sx-f3ce673b { width:100%;border-radius:6px;object-fit:cover;max-height:180px; }
.sx-fa119ec8 { width:100%;border-radius:6px;object-fit:cover;max-height:180px;display:none; }
.sx-93fb6ed7 { width:100%;border-radius:6px;object-fit:cover;max-height:200px; }
.sx-d04f5020 { width:100%;height:100%;display:block;background:#f0f4f8; }
.sx-7c1114c4 { width:100%;height:100%;object-fit:contain;padding:4px; }
.sx-7ea12b10 { width:100%;height:100%;object-fit:cover; }
.sx-624676d8 { width:100%;height:100px;object-fit:contain;background:#f4f6fa;border-radius:4px; }
.sx-5fadf304 { width:100%;height:120px;object-fit:cover;border-radius:4px; }
.sx-f06e9c4c { width:100%;height:70px;object-fit:cover; }
.sx-cf5a7acc { width:100%;justify-content:center; }
.sx-ee0435f7 { width:100px; }
.sx-1c61b8ea { width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid #e9ecef; }
.sx-088cf005 { width:120px; }
.sx-db8a217b { width:120px; }
.sx-96fb0720 { width:120px;height:160px;border-radius:10px;object-fit:cover;background:#f3f4f6;border:1px solid #e5e7eb; }
.sx-2f01efdd { width:140px; }
.sx-95782264 { width:150px; }
.sx-ed5b9a51 { width:150px; }
.sx-a2ad197f { width:180px; }
.sx-43cf0a8f { width:32px;height:32px; }
.sx-93de2d4b { width:40px; }
.sx-0a4798dc { width:40px;height:40px;border-radius:50%;background:#e9ecef;display:flex;align-items:center;justify-content:center;font-weight:600;color:#868e96; }
.sx-c51e013a { width:40px;height:40px;border-radius:50%;object-fit:cover; }
.sx-9ab095ba { width:50px; }
.sx-68dba3e7 { width:50px; }
.sx-353b939e { width:56px;height:40px;background:#f4f6fa;border-radius:4px;display:flex;align-items:center;justify-content:center; }
.sx-96f300f3 { width:56px;height:40px;object-fit:contain;background:#f4f6fa;border-radius:4px; }
.sx-c5ac9c43 { width:60px; }
.sx-4d7d280a { width:64px;height:64px;border-radius:8px;object-fit:cover;background:#f3f4f6;padding:4px;border:1px solid #e5e7eb; }
.sx-f95ebd2a { width:70px; }
.sx-45e74eed { width:70px; }
.sx-8db8d854 { width:80px; }
.sx-8935a6a1 { width:80px; }
.sx-1d5b94ad { width:80px;height:60px;background:#eee;border-radius:4px;display:flex;align-items:center;justify-content:center; }
.sx-a1ea5b50 { width:80px;height:80px;background:rgba(255,255,255,0.15);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.sx-c78f4943 { width:90px; }


/* PASS 2 — CSS var-based styles */
.sx-5b46216f { margin-bottom:var(--sp-4); }
.sx-3c7898c3 { font-size:var(--fs-lg);color:var(--clr-text-secondary);border-left:4px solid var(--clr-blue);padding-left:1rem;margin-bottom:2rem;font-style:italic; }
.sx-2ae5a363 { font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--clr-gold); }
.sx-a1869f9a { font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--ls-wider);color:var(--clr-gold);margin-bottom:var(--sp-4); }
.sx-7b3081ca { display:inline-flex;align-items:center;gap:.5rem;color:var(--clr-blue);font-weight:500; }
.sx-1c471517 { font-weight:var(--fw-bold);color:var(--clr-blue); }
.sx-1bea058e { font-size:var(--fs-base);color:var(--clr-text-primary); }
.sx-da936ee3 { font-size:var(--fs-xs);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:var(--ls-wide);color:var(--clr-text-muted);margin-bottom:var(--sp-2); }
.sx-197e102f { background:var(--grad-primary);border-radius:var(--radius-xl);padding:var(--sp-6);color:white;overflow:hidden;position:relative; }
.sx-26f39b97 { background:var(--clr-blue-pale);border-radius:var(--radius-lg);padding:var(--sp-5) var(--sp-6);margin:var(--sp-4) 0;color:var(--clr-blue); }
.sx-c60cef75 { width:52px;height:52px;background:var(--grad-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-weight:var(--fw-black);font-size:var(--fs-xs);text-align:center;line-height:1.2; }
.sx-4245848f { margin-bottom:var(--sp-3); }
.sx-0fdcac89 { font-size:var(--fs-lg);font-weight:var(--fw-semi);color:var(--clr-blue);line-height:var(--lh-relaxed);margin-bottom:var(--sp-4); }
.sx-118376ce { font-size:var(--fs-sm);margin-bottom:var(--sp-3); }
.sx-db9a12a9 { display:flex;flex-direction:column;gap:var(--sp-3);margin-top:var(--sp-5); }
.sx-f7e6f95a { color:var(--clr-text-muted);padding:2rem 0;text-align:center;grid-column:1/-1; }
.sx-28ecbd65 { margin-bottom:var(--sp-6); }
.sx-fc36a0b0 { display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6); }
.sx-049b3f57 { background:var(--tblr-primary); }
.sx-755a4591 { margin-top:var(--sp-4); }
.sx-5fcb5501 { background:var(--clr-blue-pale);color:var(--clr-blue); }
.sx-80996ee8 { background:var(--grad-primary);border-radius:var(--radius-xl);padding:var(--sp-8);color:white;text-align:center;margin:var(--sp-6) 0;position:relative;overflow:hidden; }
.sx-26220c91 { padding:3rem 0;text-align:center;color:var(--clr-text-muted); }
.sx-52bcd552 { margin-bottom:var(--sp-6);color:var(--clr-text-muted);font-size:var(--fs-sm); }
.sx-ff35d682 { margin-bottom:var(--sp-10); }
.sx-21566ea5 { padding:var(--sp-5);background:var(--clr-off-white);border-radius:var(--radius-xl);border:1px solid var(--clr-border);transition:all var(--t-normal) var(--ease-out); }
.sx-f5b6e5a7 { text-align:center;padding:var(--sp-16) 0;color:var(--clr-text-muted); }
.sx-ab6e8a7e { padding:var(--sp-24) 0;background:var(--clr-off-white); }
.sx-1a242ae7 { display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--sp-5); }
.sx-9448d094 { position:relative;margin-top:var(--sp-6); }
.sx-9529b153 { line-height:1.75;color:var(--clr-text-secondary);margin:0; }
.sx-60b2c647 { width:2px;flex:1;background:var(--clr-border);margin-top:var(--sp-2); }
.sx-cdf46c1f { font-size:var(--fs-sm);color:var(--clr-blue); }
.sx-8b6f1eb5 { display:grid;grid-template-columns:1fr;gap:var(--sp-10);align-items:start; }
.sx-7ca5dbfb { margin:var(--sp-6) 0; }
.sx-b0bc6cd8 { font-size:var(--fs-md);color:var(--clr-text-secondary);margin:var(--sp-6) 0; }
.sx-518e7e2a { color:var(--clr-blue); }
.sx-62b9a2c3 { display:flex;flex-direction:column;gap:var(--sp-5); }
.sx-c0ec402a { padding:var(--sp-12) 0 var(--sp-24); }
.sx-0b84e6ea { display:grid;grid-template-columns:1fr 340px;gap:var(--sp-10);align-items:start; }
.sx-6cec5290 { color:var(--clr-text-muted); }
.sx-fd693b41 { color:#fff;margin-bottom:var(--sp-3); }
.sx-910e0ed1 { opacity:.3;margin-bottom:var(--sp-4); }
.sx-6335dd10 { margin-top:var(--sp-2); }
.sx-b482f800 { font-size:var(--fs-sm);color:var(--clr-text-secondary);margin-bottom:var(--sp-1); }
.sx-836cb9b2 { min-width:1.5rem;font-size:var(--fs-sm);color:var(--clr-text-muted);font-weight:var(--fw-bold); }
.sx-0eecba43 { width:44px;height:44px;background:var(--grad-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:white;font-weight:var(--fw-black);font-size:var(--fs-lg);margin-bottom:var(--sp-3); }
.sx-a9cfc949 { margin-top:3rem;padding-top:2rem;border-top:1px solid var(--clr-border); }
.sx-0c508f84 { font-size:var(--fs-lg);font-weight:var(--fw-semi);color:white;margin:0; }
.sx-a9ec9712 { font-size:var(--fs-3xl);font-weight:700;line-height:1.3;margin-bottom:1.5rem;color:var(--clr-text-primary); }
.sx-bddf2b4d { font-size:1.5rem;margin-bottom:var(--sp-2); }
.sx-4c9b188f { display:flex;gap:var(--sp-4);align-items:flex-start;padding:var(--sp-4);background:var(--clr-off-white);border-radius:var(--radius-lg);border-left:3px solid var(--clr-blue); }
.sx-2b453cc3 { font-size:2.5rem;font-weight:var(--fw-black);color:var(--clr-blue);line-height:1; }
.sx-02f70e85 { margin-top:var(--sp-5); }
.sx-bc34b91d { background:var(--grad-primary);border-radius:var(--radius-xl);padding:var(--sp-8);color:white;margin:var(--sp-6) 0; }
.sx-cc2ea5a2 { text-align:center;padding:var(--sp-6); }
.sx-df84af9c { margin:var(--sp-4) 0 0; }
.sx-d00e4836 { font-size:var(--fs-base);font-weight:var(--fw-bold);color:var(--clr-blue);margin-bottom:var(--sp-2); }
.sx-9ca6c52c { display:flex;gap:var(--sp-5);padding:var(--sp-6);background:var(--clr-white);border:1px solid var(--clr-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);align-items:flex-start; }
.sx-65b4ca08 { background:var(--clr-off-white);border:1px solid var(--clr-border);border-radius:var(--radius-xl);padding:var(--sp-5);text-align:center; }
.sx-351690ed { color:var(--clr-text-secondary); }
.sx-006cfe2e { margin-top:var(--sp-6);display:flex;gap:var(--sp-3);justify-content:center;flex-wrap:wrap; }
.sx-e843dba1 { margin:0 0 var(--sp-6); }
.sx-7030d3a4 { padding:var(--sp-16) 0 var(--sp-24);background:var(--clr-off-white); }
.sx-f70e18eb { color:var(--clr-text-primary); }
.sx-bbef960f { display:flex;flex-direction:column;gap:var(--sp-4);margin-top:var(--sp-4); }
.sx-f962f337 { color:rgba(255,255,255,0.65);font-size:var(--fs-md);max-width:520px;margin:0 auto var(--sp-6);line-height:var(--lh-relaxed); }
.sx-d5972a97 { text-align:center;padding:var(--sp-16) 0; }
.sx-1abeb030 { flex:1;font-size:var(--fs-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.sx-c9f7292e { margin-bottom:var(--sp-2); }
.sx-397a0167 { font-size:var(--fs-xl);margin-bottom:var(--sp-6);padding-bottom:var(--sp-3);border-bottom:2px solid var(--clr-border); }
.sx-4f6661d7 { font-size:var(--fs-xl);font-weight:var(--fw-bold); }
.sx-e2cb4bc6 { margin:0;color:var(--clr-text-primary); }
.sx-855d805d { padding: var(--sp-16) 0 var(--sp-24); }
.sx-01678ea8 { max-width:1100px;margin:0 auto var(--sp-8); }
.sx-7462761b { font-size:var(--fs-xs);color:var(--clr-text-muted);text-align:center;margin-top:var(--sp-1); }
.sx-f9a92862 { padding:var(--sp-24) 0; }
.sx-269f094b { background:var(--clr-white);border:1px solid var(--clr-border);border-radius:var(--radius-xl);padding:var(--sp-6);text-align:center; }
.sx-5dc5e8c9 { padding-top:var(--sp-3);padding-bottom:var(--sp-6); }
.sx-8add3028 { text-align:center;color:var(--clr-text-muted); }
.sx-dc50f393 { font-size:11px;color:var(--clr-text-muted);text-align:center;margin:var(--sp-3) 0 0; }
.sx-f1a5b5d5 { margin:0 auto var(--sp-4); }
.sx-560eda1b { margin-bottom:var(--sp-5); }
.sx-f7a29ad1 { font-size:var(--fs-sm);color:var(--clr-text-secondary);line-height:1.6;margin:var(--sp-3) 0 var(--sp-4); }
.sx-88986298 { background:var(--clr-blue-pale);border-radius:var(--radius-lg);padding:var(--sp-5) var(--sp-6);margin-bottom:var(--sp-6);color:var(--clr-blue); }
.sx-79bbb9fd { font-size:var(--fs-base);font-weight:var(--fw-bold);color:var(--clr-text-primary);margin-bottom:var(--sp-2); }
.sx-1509f7fe { font-size:var(--fs-sm);font-weight:var(--fw-semi);color:var(--clr-text-primary); }
.sx-06a92e12 { display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--sp-3);border-bottom:1px solid rgba(255,255,255,0.1); }
.sx-05fb1462 { font-size:var(--fs-sm);margin-bottom:var(--sp-4); }
.sx-eb95aaac { background:var(--grad-primary);border-radius:var(--radius-xl);padding:var(--sp-8);color:white;margin:var(--sp-6) 0;display:flex;align-items:center;gap:var(--sp-6);flex-wrap:wrap; }
.sx-c86d6596 { width:52px;height:52px;background:var(--clr-blue-pale);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.sx-da7cce8b { padding:2rem 0;text-align:center;color:var(--clr-text-muted); }
.sx-2be6bb6e { display:flex;justify-content:space-between;margin-top:var(--sp-2);font-size:var(--fs-xs);color:var(--clr-text-muted); }
.sx-29cbe19e { font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--clr-blue);white-space:nowrap; }
.sx-a00cbf48 { display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);font-weight:var(--fw-semi);color:var(--clr-blue);margin-bottom:var(--sp-8); }
.sx-428990b8 { padding:var(--sp-16) 0 var(--sp-24); }
.sx-07a2e338 { display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-5);margin-bottom:var(--sp-10); }
.sx-26011663 { padding:var(--sp-12) 0 var(--sp-20);max-width:880px;margin:0 auto; }
.sx-e437bff4 { font-size:var(--fs-lg);font-weight:var(--fw-semi);color:white;line-height:var(--lh-relaxed);margin:0;position:relative;z-index:1; }
.sx-e758af31 { font-size:var(--fs-xs);opacity:0.7;letter-spacing:var(--ls-wider);text-transform:uppercase;margin-bottom:var(--sp-3); }
.sx-c4a07db2 { border-left:4px solid var(--clr-blue); }
.sx-e786c0de { background:var(--clr-blue-pale);border:1px solid rgba(6,122,193,0.15);border-radius:var(--radius-lg);padding:var(--sp-5); }
.sx-eb5a1218 { display:flex;flex-direction:column;gap:var(--sp-2);margin-top:var(--sp-4); }
.sx-4535933a { width:48px;height:48px;background:var(--clr-blue-pale);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.sx-83984691 { display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--clr-border); }
.sx-6a65d7ef { width:64px;height:64px;object-fit:contain;margin-bottom:var(--sp-2); }
.sx-b956bac9 { margin:0 0 var(--sp-5); }
.sx-8b5f2855 { line-height:1.75;color:var(--clr-text-secondary);margin:var(--sp-4) 0 var(--sp-4); }
.sx-c7a09100 { opacity:.25;margin-bottom:var(--sp-4);color:var(--clr-text-muted); }
.sx-218f3109 { width:36px;height:36px;background:var(--grad-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:white;font-weight:var(--fw-black);font-size:var(--fs-sm); }
.sx-b6314ceb { margin-top:var(--sp-6); }
.sx-9a28ac54 { display:flex;flex-direction:column;gap:var(--sp-4); }
.sx-69619a50 { line-height:1.75;color:var(--clr-text-secondary);margin:0 0 var(--sp-4); }
.sx-65c7a7b1 { font-size:var(--fs-xs);color:var(--clr-text-muted);margin-bottom:var(--sp-1); }
.sx-57b7c2b2 { color:var(--clr-text-muted);font-size:var(--fs-sm); }
.sx-5cef1909 { width:64px;height:64px;background:var(--clr-blue-pale);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-2); }
.sx-4114cebc { width:52px;height:52px;background:var(--clr-white);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border:1px solid var(--clr-border); }
.sx-c9dcdaa0 { color:var(--clr-text-muted);padding:2rem 0; }
.sx-b9227763 { font-size:var(--fs-sm);color:rgba(255,255,255,0.7); }
.sx-da77625f { font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--clr-blue);margin-bottom:var(--sp-2); }
.sx-2a263b4e { font-size:var(--fs-md);color:var(--clr-text-secondary);margin:0;line-height:1.7; }
.sx-e4411574 { font-size:var(--fs-xs);color:var(--clr-text-secondary); }
.sx-f6c6fe1d { font-size:var(--fs-xs);color:var(--clr-text-secondary);line-height:var(--lh-relaxed); }
.sx-ba3b3c67 { background:var(--clr-blue-glass);border-left:4px solid var(--clr-blue);border-radius:var(--radius-lg);padding:var(--sp-6);margin-top:var(--sp-8); }
.sx-eeb21fb9 { display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);font-weight:var(--fw-semi);color:var(--clr-blue);margin-bottom:var(--sp-8);transition:gap var(--t-fast); }
.sx-00c4b4b9 { display:flex;gap:var(--sp-5);margin-bottom:var(--sp-6);position:relative; }
.sx-a8867b23 { font-size:var(--fs-sm);opacity:0.8;margin-top:var(--sp-1); }
.sx-f08d45c9 { font-size:var(--fs-sm);font-weight:var(--fw-bold);color:white; }
.sx-4425894c { font-size:var(--fs-xs);opacity:0.7;letter-spacing:var(--ls-wider);text-transform:uppercase;margin-bottom:var(--sp-1); }
.sx-3d2a019f { margin:0;font-size:var(--fs-2xl); }
.sx-346c7217 { color:var(--clr-text-muted); }
.sx-bf428402 { margin-top:var(--sp-8);font-size:var(--fs-xs);color:var(--clr-text-muted);text-align:center; }
.sx-c901d723 { margin-top:var(--sp-8); }


.d-none-util { display: none !important; }

