:root{
  --bg: #ffffff;
  --text: #000000;
  --muted: #5a5a5a;
  --accent: #bb2929; /* oranye seperti di gambar */
  --header-h: 78px;
  --container: 1200px;
  --pad-x: 28px;

  --shadow: 0 6px 18px rgba(0,0,0,.12);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
}

/* =======================
   TOP NAV
======================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 9999;
  /* Gradient opaque (tanpa transparansi) */
  background: linear-gradient(90deg, #ffffff 20%, #971f1f 60%);
  border-bottom: 0px solid rgba(0,0,0,.06);
}

.nav-wrap{
  height: var(--header-h);
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 20px;
}

.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
  color: inherit;
}

.brand-logo{
  position: absolute;
  left: 0%;
  width: 70px;
  height: 70px;
  display: flex;
  object-fit: contain;
}

.brand-mark{
  position: absolute;
  left: 20mm;
  font-weight: 700;
  font-size: 22px;
  letter-spacing: .30em;
  color: var(--accent);
  line-height: normal;
}

.brand-word{
  position: absolute;
  left: 40mm;
  font-weight: 500;
  letter-spacing: .35em;
  font-size: 22px;
  color: #2a2a2a;
}

.nav{
  position: absolute;
  right: 10mm;
  display:flex;
  align-items:end;
}

.nav-list{
  list-style: none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap: 26px;
}

.nav-link{
  font: inherit;
  font-weight: 600;
  font-size: 15px;
  color: #d9d6d6;
  text-decoration:none;
  padding: 10px 2px;
  position: relative;
  background: transparent;
  border: 0;
  cursor: pointer;
}

.nav-link:hover{ color:#787676; }

.nav-link.active {
  color: #787676;
}

.has-dropdown{ position: relative; }

.nav-btn{
  display:flex;
  align-items:center;
  gap: 8px;
}

/* chevron kecil seperti dropdown */
.chev{
  width: 7px;
  height: 7px;
  border-right: 2px solid #ffffff;
  border-bottom: 2px solid #ffffff;
  transform: rotate(45deg);
  margin-top: -2px;
  opacity: .9;
}

/* dropdown */
.dropdown{
  position:absolute;
  top: 100%;
  left: -10px;
  min-width: 200px;
  list-style:none;
  margin:0;
  padding: 10px 0;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 12px;
  box-shadow: var(--shadow);

  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}

.dropdown a{
  display:block;
  padding: 10px 14px;
  text-decoration:none;
  color: #333;
  font-weight: 600;
  font-size: 14px;
}

.dropdown a:hover{
  background: rgba(212,154,31,.12);
}

.has-dropdown:hover .dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

body.is-blurred #page-content {
  filter: blur(20px);
  opacity: 0.6;
  pointer-events: none;
  transform: scale(0.98);
}

#page-content {
  transition: filter 0.8s cubic-bezier(0.16, 1, 0.3, 1), 
              opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: filter, transform, opacity;
}

.has-dropdown.open .chev{
  transform: rotate(225deg);
}

/* hamburger (hidden desktop) */
.nav-toggle{
  display:none;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(0,0,0,.10);
  background:#fff;
  border-radius: 12px;
  padding: 10px;
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  height: 2px;
  background:#222;
  border-radius: 2px;
  margin: 6px 0;
}

/* =======================
   HERO (Masthead)
======================= */
.masthead{
  min-height: 520px;
  position: relative;
  /* Agar transisi scale lebih halus jika ada perubahan via JS */
  will-change: transform, opacity;
  overflow: hidden; /* Pastikan background yang di-penyet tidak bocor (walaupun scale down) */
  background: 
    linear-gradient(90deg, rgba(0,0,0,.07), rgba(0,0,0,0) 60%),
    radial-gradient(circle at 70% 30%, #8a1a1a 0%, #4a0a0a 100%);
}

/* Background dipisah biar bisa di-penyet tanpa merusak teks */
.masthead-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  
  /* Background dipindah ke sini */
  background: 
    /*linear-gradient(90deg, rgba(99, 77, 77, 0.171)30%, rgba(105, 77, 77, 0.945)75%, rgba(207, 49, 49, 0.966)99%), */
    url("digantifotobareng.jpg") center/cover no-repeat;
    
  z-index: -1; /* Di belakang teks */
  
  /* Origin di atas, biar pas scaleY < 1, dia naik dari bawah (nge-pendek) */
  transform-origin: top center;
  will-change: transform;
}

/* Masthead Blurred (Apple Style) - Moved to kepengurusan.css */

/* Override masthead-board jika masih ada yang pakai, tapi di sini kita pakai class baru */
.masthead-board{
  position: relative;
  min-height: clamp(360px, 60vh, 640px);
  overflow: hidden;
  background: transparent;
}
.masthead-board-left{
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 50%;
  background: radial-gradient(circle at 80% 20%, #8a1a1a 0%, #4a0a0a 100%);
  transform-origin: top center;
  will-change: transform;
}
.masthead-board-right{
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 50%;
  background: url("board.png") center bottom/cover no-repeat;
  transform-origin: top center;
  will-change: transform;
}
.masthead-board .masthead-inner{
  max-width: none;
  width: 50%;
  margin: 0;
  padding: 80px var(--pad-x) 80px;
  position: relative;
  z-index: 1;
}
.masthead-board .judul-kps,
.masthead-board .hero-copy{
  position: static;
  left: auto;
  top: auto;
}
.masthead-board .judul-kps{
  display: block;
  margin: 0 0 10px;
  color: #ffffff;
  font-size: clamp(34px, 6vw, 60px);
  font-weight: 800;
  letter-spacing: .01em;
  line-height: 1.05;
}
.masthead-board .hero-copy{
  color: #1a1a1a;
  max-width: 46ch;
  font-weight: 500;
}

.masthead-inner{
  max-width: var(--container);
  margin: 0 auto;
  padding: 90px var(--pad-x) 80px;
  position: relative; /* Pastikan z-index bekerja jika perlu */
  z-index: 1;
}

.judul-kps{
  position: absolute;
  left: 30mm;
  top: 40mm;
  display: flex;
  align-items: normal;
  font-size: clamp(40px, 50px, 50px);
  color: #d83333;
  font-weight: 600;
}

.fh-uner{
  position: absolute;
  left: 30mm;
  top: 55mm;
  color:#fff;
  letter-spacing: .12em;
  font-size: clamp(20px, 30px, 30px);
  text-shadow: 0 8px 24px rgba(0,0,0,.35);
  font-weight: 400;
}

.hero-copy{
  position: absolute;
  left: 30mm;
  top: 65mm;
  margin:0;
  color:#fff;
  font-size: clamp(16px, 1.6vw, 22px);
  line-height: 1.2;
  font-weight: 500;
  text-shadow: 0 8px 24px rgba(0,0,0,.45);
  max-width: 760px;
}

/* =========================
   FEATURE SECTION (ORANGE/RED)
========================= */
.feature-allam{
  position: relative;
  overflow-x: hidden;
  isolation: isolate;           /* bikin layer z-index aman */
  background-color: #ffffff;
}

/* Background terpisah untuk efek squash */
.feature-allam-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  
  background: radial-gradient(circle at 70% 30%, #8a1a1a 0%, #4a0a0a 100%);
  
  transform-origin: top center; /* Squash dari atas */
  will-change: transform;
}

.feature-allam::before{
  /* Tetap di container utama */
  content:"";
  position:absolute;
  inset: 0;
  z-index: 0;
  pointer-events:none;
}

/* shading halus sisi kiri (opsional) - INI YG BIKIN GRADASI GELAP */
/* Kita pindahkan ke .feature-allam-bg supaya ikut squash */
.feature-allam-bg::after{
  content:"";
  position:absolute;
  inset:0;
  z-index: 0;
  pointer-events:none;
  background: linear-gradient(90deg, rgba(0,0,0,.07), rgba(0,0,0,0) 60%);
}

.feature-inner{
  position: relative;
  z-index: 2;                   /* di atas watermark & gambar */
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(60px, 8vw, 96px) 28px;
  min-height: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.feature-content{
  margin-top: 0;
  margin-bottom: 40px;
  max-width: 880px;
}

/* headline */
.feature-headline{
  margin: 0 0 20px;
  line-height: 1.15;
  letter-spacing: .01em;
  font-size: clamp(28px, 3.2vw, 40px);
  font-weight: 800;
  color: #ffffff;
}

/* paragraf */
.feature-desc{
  margin: 0 0 16px;
  color: #f5f5f5 !important;
  font-weight: 350;
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.6;
  max-width: 72ch;
}

.feature-highlight{
  color: #ffffff;
  font-weight: 800;
}

/* tombol pill */
.feature-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 48px;
  padding: 0 35px;
  border-radius: 999px;

  background: #ffffff;
  color: #474747;
  font-weight: 700;
  font-size: 18px;
  text-decoration: none;

  box-shadow: none;

  transition: 
  background-color 400ms cubic-bezier(.2,.8,.2,1),
  color 800ms cubic-bezier(.2,.8,.2,1);
}

.feature-btn:hover{
  background: #474747; 
  color: #ffffff;      
}

.feature-btn:focus-visible{
  outline: 2px solid #474747;
  outline-offset: 3px;
}

.feature-media{
  display: none;
}

.feature-media img{
  display: none;
}

/* metrics */
.feature-metrics{
  width: 100%;
  max-width: 900px;
  margin-top: 24px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 32px;
}

.feature-metric{
  text-align: center;
  color: #f5f5f5;
}

.feature-metric-number{
  font-size: clamp(32px, 3.6vw, 44px);
  font-weight: 800;
  margin-bottom: 4px;
}

.feature-metric-label-main{
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 2px;
}

.feature-metric-label-sub{
  font-size: 13px;
  opacity: .9;
}

@media (max-width: 900px){
  .feature-inner{
    padding: 54px 24px;
  }
  .feature-metrics{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: 26px;
  }
}

@media (max-width: 560px){
  .feature-inner{
    padding: 46px 20px;
  }
  .feature-content{
    margin-bottom: 32px;
  }
  .feature-metrics{
    grid-template-columns: 1fr 1fr;
    column-gap: 18px;
    row-gap: 22px;
  }
}

/* =======================
   RESPONSIVE
======================= */
@media (max-width: 980px){
  .nav-toggle{ display:block; }

  .nav{
    position: absolute;
    top: var(--header-h);
    left: 0;
    right: 0;
    background:#fff;
    border-bottom: 1px solid rgba(0,0,0,.06);
    transform: translateY(-8px);
    opacity: 0;
    pointer-events: none;
    transition: .16s ease;
  }

  .site-header.nav-open .nav{
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  .nav-list{
    max-width: var(--container);
    margin: 0 auto;
    padding: 12px var(--pad-x) 18px;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .dropdown{
    position: static;
    box-shadow: none;
    border: none;
    border-radius: 0;
    padding: 0 0 8px 10px;
    opacity: 1;
    transform: none;
    pointer-events: auto;
    display: none;
    margin-top: 4px;
  }

  .has-dropdown.open .dropdown{ display:block; }

  .masthead-inner{
    padding-top: 54px;
  }
}

@media (max-width: 520px){
  .brand-word{ font-size: 18px; letter-spacing:.28em; }
  .brand-mark{ font-size: 24px; }
}

/* =========================
   SAMBUTAN KETUA (Preface-like)
========================= */
.preface{
  background: #ffffff;
  padding: 0;
  margin-top: 0; /* Memastikan tidak ada margin atas */
}

.preface-head{
  max-width: none;
  width: calc(100% - 24px);
  margin: 0 12px 10px;
  padding: 0;
  text-align: left;
}
.preface-heading{
  margin: 0;
  color: #0a0a0a;
  font-weight: 700;
  font-size: clamp(26px, 2.6vw, 34px);
  letter-spacing: .01em;
}

.preface-wrap{
  max-width: none;
  width: calc(100% - 24px);
  margin: 0 12px;
  padding: 56px 40px; /* Padding vertikal ditingkatkan untuk menambah tinggi */
  border-radius: 24px;
  background: linear-gradient(135deg, #b6acaccd, #ac2929);
  overflow: hidden;
  min-height: auto;

  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 48px; /* Gap ditingkatkan agar lebih lega */
  align-items: center; 
}

/* kartu teks (kiri) */
.preface-card{
  display: flex;
  align-items: center;
}

/* LEFT IMAGE CARD */
.preface-media{
  margin: 0;
  overflow: hidden;
  box-shadow: none;
  border-radius: 18px;
  background: transparent;
  align-self: stretch;
}

.preface-photo-card{
  border-radius: 26px;
  overflow: hidden;
  background:
    radial-gradient(1200px 600px at 50% 110%, rgba(255,255,255,.05), transparent 60%),
    linear-gradient(120deg, #ac2929 0%, #f7f7f7 80%);
  justify-self: start;
  height: 520px;
  max-height: none;
}
.preface-photo-card .preface-media{ border-radius: 0; }

.preface-media img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;        
  object-position: bottom center;
}
@media (min-width: 900px){
  .preface-media img{
    transform: none;
  }
}

/* RIGHT CONTENT */
.preface-title{
  display: none;
}

.preface-text{
  color: #0a0a0a;
  font-size: clamp(15px, 1.6vw, 18px); /* Kembalikan ke ukuran yang lebih lega */
  line-height: 1.6;
  max-width: 720px;
}

.preface-text p{
  margin: 0 0 12px; /* Tambah margin antar paragraf */
  text-align: justify;
}

.preface-sign{
  margin-top: 24px; /* Tambah jarak ke tanda tangan */
  color: #0a0a0a;
  line-height: 1.2;
}
.preface-sign strong{
  display: block;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 800;
  margin-bottom: 4px;
  color: #0a0a0a; /* Warna teks diubah menjadi hitam */
}
.preface-role{
  display: block;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 600;
  opacity: .9;
  color: #0a0a0a; /* Warna teks diubah menjadi hitam */
}

/* =========================
   VARIAN UNTUK PNG ORANG TANPA BACKGROUND
   Jika PNG ketua transparan dan kamu ingin terlihat "contain" dan ada ruang,
   aktifkan class .is-transparent pada figure.
========================= */
.preface-media.is-transparent{
  background: transparent;
}

.preface-media.is-transparent img{
  object-fit: cover;
  height: 100%;
  padding: 0;
  transform: translateY(20px);
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 980px){
  .preface-heading{
    margin-left: 0;
    text-align: center;
  }
  .preface-head{
    text-align: center;
    margin: 0 auto 20px;
  }
  .preface-wrap{
    grid-template-columns: 1fr;
    padding: 30px;
    width: calc(100% - 24px);
    margin: 0 12px;
    gap: 30px;
  }

  .preface-photo-card{
    justify-self: center;
    width: 100%;
    max-width: 500px;
    min-height: 250px;
    padding-left: 0;
  }
  
  .preface-photo-card .preface-media{
    height: 100%;
  }
  .preface-photo-card .preface-media img{
    height: 100%;
    object-fit: cover;
    object-position: bottom center;
  }

  .preface-text{
    max-width: 100%;
    text-align: left;
  }
  .preface-text p {
    text-align: left;
  }
}

@media (max-width: 520px){
  .preface-wrap{
    padding: 24px 18px;
    width: calc(100% - 16px);
    margin: 0 8px;
    gap: 20px;
  }

  .preface-photo-card{
    min-height: 200px;
  }

  .preface-media{
    height: 100%;
    margin-bottom: 0;
  }
  
  .preface-media.is-transparent img{
    transform: translateY(0);
  }
  
  .preface-content{
    margin-top: 0;
  }
}

/* ====== NAVBAR SHRINK ON SCROLL (ADD-ON ONLY) ====== */

/* animasi halus */
.site-header,
.nav-wrap,
.brand-logo,
.brand-mark,
.brand-word,
.nav-link{
  transition: all .22s ease;
}

/* saat scroll: tinggi header & padding mengecil */
.site-header.is-scrolled .nav-wrap{
  height: calc(var(--header-h) - 20px);
  padding-top: 6px;
  padding-bottom: 6px;
}

/* kecilkan logo & teks brand */
.site-header.is-scrolled .brand-logo{
  width: 54px;
  height: 54px;
}

/* geser sedikit supaya tetap rapi ketika mengecil */
.site-header.is-scrolled .brand-mark{
  transform: translateX(-4px) scale(.92);
}

.site-header.is-scrolled .brand-word{
  transform: translateX(-6px) scale(.92);
}

/* kecilkan menu */
.site-header.is-scrolled .nav-link{
  font-size: 13px;
  padding: 8px 2px;
}

/* (opsional) kasih shadow halus biar terasa “compact” */
.site-header.is-scrolled{
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
}

/* =========================
   TRI CARDS (BIG SCALE)
========================= */
.tri-cards{
  background:#fff;
  padding: 84px 0 110px;
}

.tri-wrap{
  max-width: 1800px;     /* lebih lebar biar skala mirip screenshot */
  margin: 0 auto;
  padding: 0 60px;

  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 52px;             /* jarak antar card lebih besar */
}

/* CARD BASE */
.tri-card{
  position: relative;
  overflow: hidden;
  border-radius: 26px;
  min-height: 640px; 
  box-shadow: 0 18px 34px rgba(0,0,0,.16);
  background: #ffffff;
  transform: translateY(0) scale(1);
  transition: transform 400ms cubic-bezier(.2,.8,.2,1), box-shadow 400ms cubic-bezier(.2,.8,.2,1);
  will-change: transform;
  --imgH: clamp(240px, 40%, 300px);
  cursor: pointer;
}

/* background image */
.tri-bg{
  position:absolute;
  left:0; right:0; bottom:0;
  width:100%;
  height: var(--imgH);
  object-fit: cover;
  object-position: center bottom;
  z-index: 0;
}

.tri-card:hover,
.tri-card:focus-within{
  transform: translateY(-8px) scale(1.01);
  box-shadow: 0 26px 48px rgba(0,0,0,.20);
}

.tri-card:active{
  transform: translateY(-6px) scale(1.005);
  box-shadow: 0 22px 42px rgba(0,0,0,.18);
}

/* overlay warna utama */
.tri-card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  opacity:0;
  background: none;
}

/* overlay gelap halus untuk kontras teks */
.tri-card::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background: none;
  opacity:0;
}

/* warna sesuai request */
.tri-blue{  background: linear-gradient(180deg, #9d3131, #232323); color:#ffffff; }
.tri-amber{ background: #fafafade; color:#0a0a0a; }
.tri-green{ background: linear-gradient(180deg, #0a0a0a, #222222); color:#ffffff; }

/* CONTENT */
.tri-content{
  position: relative;
  z-index:2;
  height:100%;

  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;

  padding: 26px 26px calc(var(--imgH) + 26px);
  color: inherit;
}

.tri-title{
  margin:0 0 24px;
  font-weight: 800;
  letter-spacing: .08em;
  line-height: 0.9;
  font-size: 30px;
  color: currentColor;
}

/* teks tengah (bold) */
.tri-sub{
  margin:0 0 16px;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.25;
  max-width: 28ch;
  color: currentColor;
}

/* teks bawah */
.tri-desc{
  margin:0;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.35;
  opacity: .9;
  max-width: 42ch;
  text-align: left;
  color: currentColor;
}

/* tombol */
.tri-btn{
  position: absolute;
  inset: 0;
  z-index: 4;
  display: block;
  background: transparent;
  border: 0;
  color: transparent;
  text-indent: -9999px;
  opacity: 0;
}

.tri-blue  .tri-btn{ background:#bb2929; border-color:#bb2929; }
.tri-amber .tri-btn{ background:#f29416; border-color:#f29416; }
.tri-green .tri-btn{ background:#5bd332; border-color:#5bd332; }

.tri-blue  .tri-btn:hover,
.tri-amber .tri-btn:hover,
.tri-green .tri-btn:hover{
  background:#ffffff;
  color:#505050;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 1100px){
  .tri-wrap{
    max-width: 1100px;
    padding: 0 28px;
    gap: 34px;
  }
  .tri-card{ min-height: 640px; }
  .tri-content{ padding: 82px 38px 54px; }
}

@media (max-width: 900px){
  .tri-wrap{
    grid-template-columns: 1fr;
    gap: 26px;
    padding: 0 20px;
  }
  .tri-card{ min-height: 560px; }
}

/* =========================
   NEWS SECTION (3 cards)
========================= */
.news{
  background: #ffffff;
  padding: 70px 0 90px;
}

.news-wrap{
  max-width: 2000px;
  margin: 0 auto;
  padding: 0 44px;
}

.news-title{
  margin: 0 0 40px;
  text-align: center;
  font-size: 32px;
  letter-spacing: .01em;
}

.news-title--item{
  color: #0a0a0a;
  font-weight: 700;
}

.news-title--putih{
  color: #6a6a6a;
  font-weight: 600;
}
@media (min-width: 900px){
  .news-title{
    white-space: nowrap;
  }
}
/* ===== carousel viewport ===== */
.news-carousel{
  position: relative;
  overflow: hidden;
  padding: 6px 0;
}

/* track berjalan */
.news-track{
  display: flex;
  gap: 26px;
  align-items: stretch;
  will-change: transform;
  transition: transform 600ms cubic-bezier(.2,.8,.2,1);
}

/* card */
.news-card{
  --gradStart: #0f0f0f;
  --gradEnd: #1e1e1e;
  flex: 0 0 420px;
  position: relative;
  color: #fff;
  border-radius: 26px;
  padding: 40px 32px 56px;
  background:
    radial-gradient(1000px 400px at 50% 110%, rgba(255,255,255,.08), transparent 60%),
    linear-gradient(180deg, var(--gradStart), var(--gradEnd));
  min-height: 640px;
  max-width: 508px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  overflow: visible;
}

.news-label{
  margin: 0 0 10px;
  color: rgba(255,255,255,.86);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .02em;
}

.news-head{
  margin: 0 0 6px;
  color: #ffffff;
  font-weight: 800;
  font-size: clamp(20px, 2.6vw, 28px);
  line-height: 1.05;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
  hyphens: auto;
}

.news-sub{
  margin: 6px 0 0;
  color: rgba(255,255,255,.85);
  font-size: clamp(14px, 2vw, 17px);
  font-weight: 600;
  line-height: 1.25;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
}


/* efek fade kiri-kanan biar mirip carousel modern */
.news-carousel::before,
.news-carousel::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 80px;
  z-index: 2;
  pointer-events:none;
}

.news-carousel::before{
  left:0;
  background: linear-gradient(90deg, #ffffff 0%, rgba(255,255,255,0) 100%);
}

.news-carousel::after{
  right:0;
  background: linear-gradient(270deg, #ffffff 0%, rgba(255,255,255,0) 100%);
}

/* responsive: card jadi lebih lebar relatif layar */
@media (max-width: 900px){
  .news-wrap{ padding: 0 20px; }
  .news-card{ flex-basis: min(86vw, 420px); }
}

@media (min-width: 900px){
  .news-card{
    flex: 0 0 calc((100% - 52px) / 3);
    max-width: none;
  }
}

.news-shell{
  position: relative;
}

/* viewport */
.news-carousel{
  position: relative;
  overflow: hidden;
  padding: 6px 0;
}

/* track */
.news-track{
  display: flex;
  gap: 26px;
  align-items: stretch;
  will-change: transform;
}

/* tombol panah */
.news-arrow{
  position: absolute;
  bottom: -40px;
  transform: none;
  z-index: 5;

  width: 46px;
  height: 46px;
  border-radius: 999px;

  border: 1px solid rgba(0,0,0,.12);
  background: rgba(240,240,240,.8);
  backdrop-filter: blur(8px);

  color: #111111;
  font-size: 28px;
  line-height: 1;
  display: grid;
  place-items: center;

  cursor: pointer;
  transition: background-color 220ms ease, transform 220ms ease, border-color 220ms ease;
}

.news-arrow:hover{
  background: rgba(250,250,250,1);
  border-color: rgba(0,0,0,.22);
}

.news-arrow:active{
  transform: scale(.98);
}

.news-arrow.prev{ right: 64px; }
.news-arrow.next{ right: 14px; }

/* responsive: panah agak masuk */
@media (max-width: 900px){
  .news-arrow.prev{ left: 6px; }
  .news-arrow.next{ right: 6px; }
}

/* contoh palette gradient ala apple */
.news-card:nth-child(1){ --gradStart:#0a0a0a; --gradEnd:#a4845d; }
.news-card:nth-child(2){ --gradStart:#912d2d; --gradEnd:#bf4d4d; }
.news-card:nth-child(3){ --gradStart:#af4848; --gradEnd:#222222; }
.news-card:nth-child(4){ --gradStart:#15223a; --gradEnd:#9a2828; }
.news-card:nth-child(5){ --gradStart:#0a0a0a; --gradEnd:#c33131; }
.news-card:nth-child(6){ --gradStart:#2a2a2a; --gradEnd:#3b3b3b; }
.news-card:nth-child(7){ --gradStart:#b64e36; --gradEnd:#81988b; }
.news-card:nth-child(8){ --gradStart:#5b2d2d; --gradEnd:#9a4d4d; }
.news-card:nth-child(9){ --gradStart:#0a1f3a; --gradEnd:#a0592e; }
.news-card:nth-child(10){ --gradStart:#443f49; --gradEnd:#a45151; }

/* =========================
   PARTNERS SECTION
========================= */
.partners{
  width: 100%;
}

/* BAGIAN JUDUL */
.partners-top{
  background: #ffffff;
  padding: 40px 0 20px;
  text-align: center;
}

.partners-title{
  margin: 0;
  color: #0a0a0a;
  font-weight: 800;
  font-size: clamp(26px, 2.6vw, 32px);
  letter-spacing: .01em;
}

/* grid logo sederhana */
.partners-logos{
  max-width: 1200px;
  margin: 0 auto 40px;
  padding: 0 24px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 40px 80px;
  text-align: center;
  transform: translateX(clamp(48px, 6vw, 110px));
}
.partners-logos img{
  /* Pakai width & height fixed untuk container visual yang sama */
  width: 250px; /* Diperbesar lagi dari 200px */
  height: 125px; /* Diperbesar lagi dari 100px */
  /* object-fit: contain bikin gambar pas di dalam kotak tanpa gepeng */
  object-fit: contain;
  object-position: center;

  filter: none;
  opacity: 1;
  transition: all 300ms ease;
}
/* Partner 2 (urutan pertama di HTML) */
.partners-logos img:nth-child(1) {
  width: 250px;
  height: 125px;
}
.partners-logos img:hover{
  transform: scale(1.05);
}
@media (max-width: 900px){
  .partners-logos{
    gap: 30px 50px;
  }
  .partners-logos img{ 
    width: 180px; 
    height: 90px; 
  }
  .partners-logos img:nth-child(1) {
    width: 180px;
    height: 90px;
  }
}
@media (max-width: 560px){
  .partners-logos{ 
    gap: 24px 30px;
    /* Pastikan center di mobile */
    justify-content: center; 
    transform: none;
  }
  .partners-logos img{ 
    width: 140px; 
    height: 70px; 
  }
  .partners-logos img:nth-child(1) {
    width: 140px;
    height: 70px;
  }
}

/* BAGIAN LOGO (MERAH) */
.partners-bar{
  background: #b81515;            /* ✅ merah (ubah sesuai yang kamu mau) */
  padding: 60px 0 60px;
}

/* viewport carousel */
.partners-carousel{
  max-width: 1500px;
  margin: 0 auto;
  padding: 0 40px;

  overflow: hidden;
  position: relative;
}

/* track berjalan */
.partners-track{
  display: flex;
  align-items: center;
  gap: 26px;
  will-change: transform;
}

/* kartu logo putih */
.partner{
  flex: 0 0 auto;

  width: 240px;                   /* skala seperti contoh */
  height: 74px;
  background: #ffffff;
  border-radius: 6px;

  display: flex;
  align-items: center;
  justify-content: center;

  box-shadow: 0 10px 18px rgba(255, 255, 255, 0.18);
}

.partner img{
  max-width: 78%;
  max-height: 60%;
  object-fit: contain;
  display: block;
}

/* fade kiri-kanan biar terasa carousel */
.partners-carousel::before,
.partners-carousel::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 90px;
  z-index: 2;
  pointer-events:none;
}

.partners-carousel::before{
  left:0;
  background: linear-gradient(90deg, #b81515 0%, rgba(184,21,21,0) 100%);
}
.partners-carousel::after{
  right:0;
  background: linear-gradient(270deg, #b81515 0%, rgba(184,21,21,0) 100%);
}

/* responsive */
@media (max-width: 900px){
  .partner{
    width: 200px;
    height: 68px;
  }
  .partners-carousel{
    padding: 0 18px;
  }
}

.delegasi-section{
  background: #ffffff;
  padding: clamp(72px, 9vw, 104px) 0;
}

.delegasi-inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--pad-x);
}

.delegasi-head{
  max-width: 720px;
  margin: 0 auto 12px;
  text-align: center;
}

.delegasi-eyebrow{
  margin: 0 0 10px;
  font-size: 13px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #b81515;
}

.delegasi-title{
  margin: 0 0 10px;
  font-size: clamp(30px, 3vw, 40px);
  font-weight: 800;
  letter-spacing: .01em;
  color: #0a0a0a;
}

.delegasi-subtitle{
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  color: #494949;
}

.delegasi-list{
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.delegasi-item{
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.1fr);
  gap: 32px;
  padding: 28px;
  border-radius: 24px;
  background: #ffffff;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.06);
  align-items: stretch;
  /* tinggi foto bareng (kembali seperti sebelumnya, tidak terlalu tinggi) */
  --delegasi-photo-h: clamp(230px, 28vw, 320px);
}

.delegasi-main{
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.delegasi-badge{
  display: inline-block;
  padding: 0;
  border-radius: 0;
  border: none;
  background: transparent;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #7a1a1a;
}

.delegasi-name{
  margin: 0;
  font-size: clamp(22px, 2.4vw, 26px);
  font-weight: 700;
  color: #0a0a0a;
}

.delegasi-meta{
  margin: 0;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #737373;
}

.delegasi-desc{
  margin: 4px 0 10px;
  font-size: 14px;
  line-height: 1.7;
  color: #404040;
}

.delegasi-group-photo{
  border-radius: 24px;
  overflow: hidden;
  position: relative;
  height: var(--delegasi-photo-h);
  background-size: cover;
  background-position: center;
  transform-origin: center;
  transition: transform 420ms cubic-bezier(.22,.61,.36,1), box-shadow 420ms ease;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.16);
}

.delegasi-item:hover .delegasi-group-photo{
  transform: translateY(-4px) scale(1.01);
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.22);
}

.delegasi-members{
  position: relative;
  padding: 14px 10px 0 22px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.delegasi-members-title{
  margin: 0 0 8px;
  font-size: 13px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #6b6b6b;
}

.delegasi-members-grid{
  list-style: none;
  margin: 0;
  padding: 0 6px 0 0;
  position: relative;
  /* tinggi viewport nama anggota lebih panjang dari foto,
     supaya sampai kira-kira anggota ke-7 masih kelihatan tanpa scroll */
  max-height: clamp(360px, 42vw, 540px);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(184,21,21,0.45) rgba(0,0,0,0.02);
}

.delegasi-member{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0 14px 24px;
  position: relative;
}

.delegasi-member::before{
  content: "";
  position: absolute;
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 2px solid #ffffff;
  background: #b81515;
  box-shadow: 0 0 0 1px rgba(184,21,21,0.28);
}

.delegasi-members-grid::before{
  content: "";
  position: absolute;
  left: 8px;
  top: 4px;
  bottom: 4px;
  width: 2px;
  background: linear-gradient(
    to bottom,
    rgba(184,21,21,0.05),
    rgba(184,21,21,0.35)
  );
}

.delegasi-member-photo{
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
}

.delegasi-member-text{
  min-width: 0;
}

.delegasi-member-name{
  margin: 0 0 3px;
  font-size: 14px;
  font-weight: 600;
  color: #0a0a0a;
}

.delegasi-member-role{
  margin: 0;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #777777;
}

.delegasi-members-grid::-webkit-scrollbar{
  width: 6px;
}

.delegasi-members-grid::-webkit-scrollbar-track{
  background: rgba(0,0,0,0.02);
  border-radius: 999px;
}

.delegasi-members-grid::-webkit-scrollbar-thumb{
  background: rgba(184,21,21,0.45);
  border-radius: 999px;
}

.delegasi-members-grid::-webkit-scrollbar-thumb:hover{
  background: rgba(184,21,21,0.65);
}

@media (max-width: 960px){
  .delegasi-item{
    grid-template-columns: 1fr;
    padding: 22px;
  }

  .delegasi-members{
    order: 2;
  }

  .delegasi-main{
    order: 1;
  }
}

@media (max-width: 640px){
  .delegasi-section{
    padding: 56px 0 70px;
  }

  .delegasi-members-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .delegasi-item{
    border-radius: 24px;
  }
}

/* ===== FORCE NAVBAR ALWAYS ON TOP (ANTI KETIBAN LAYER) ===== */
.site-header{
  position: fixed;   /* override sticky -> fixed */
  top: 0;
  left: 0;
  right: 0;
  width: 100%;

  z-index: 9999999;
  border-bottom: 1px solid rgba(0,0,0,.10);
}

/* karena header jadi fixed, kasih ruang di atas konten */
body{
  padding-top: var(--header-h);
}

/* pas shrink: tetap rapi */
.site-header.is-scrolled{
  box-shadow: 0 12px 28px rgba(230, 81, 81, 0.14);
}

/* =========================
   CONTACT (8 Rivers-ish)
========================= */
.contact{
  background: #ffffff;
  color: #0a0a0a;
  padding: clamp(80px, 10vw, 400px) 0;
  text-align: center;
}

.contact-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 0px;

  min-height: clamp(520px, 70vh, 760px);
  position: relative;

  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-media img{
  position: static !important;   /* <- bikin dia ikut flow */
  max-width: 100% !important;
  height: auto !important;
  transform: none !important;
  display: block !important;
  margin: 0 auto !important;
}

/* konten di tengah-agak kanan seperti contoh */
.contact-content{
  width: min(900px, 92vw);
}

.contact-title{
  margin: 0 0 14px;
  font-size: clamp(48px, 6vw, 50px);
  font-weight: 800;
  letter-spacing: .01em;
  text-transform: uppercase;
  line-height: 1;
}

.contact-line{
  margin: 0 0 26px;
  font-size: 14px;
  line-height: 1.5;
  color: #3b3b3b;
}

.contact-block{
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.7;
}

.contact-link{
  color: #0a0a0a;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,.18);
  padding-bottom: 1px;
}

.contact-link:hover{
  border-bottom-color: rgba(0,0,0,.55);
}

/* footer kecil bawah */
.contact-footer{
  position: absolute;
  bottom: 180px;
  display: grid;
  align-items: center;
  font-size: 40px;
  color: #6a6a6a;
}

.contact-social{
  display: flex;
  align-items: center;
  gap: 12px;
}

.contact-ic{
  color: #6a6a6a;
  text-decoration: none;
  font-weight: 700;
  letter-spacing: .02em;
}

.contact-ic:hover{ color:#0a0a0a; }

.contact-lang{
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 8px;
}

.contact-langbtn{
  border: 0;
  background: transparent;
  color: #6a6a6a;
  font: inherit;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 8px;
}

.contact-langbtn.is-active{
  color: #0a0a0a;
  font-weight: 800;
}

.contact-langsep{ opacity: .55; }

/* =========================
   REVEAL ANIMATION (fade-up)
========================= */
.contact-reveal{
  opacity: 0;
  transform: translateY(26px);
  transition:
    opacity 600ms cubic-bezier(.2,.8,.2,1),
    transform 650ms cubic-bezier(.2,.8,.2,1);
}

.contact-reveal.is-inview{
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce){
  .contact-reveal{
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* responsive: kecilkan/geser visual */
@media (max-width: 820px){
  .contact-visual{
    left: 12px;
    width: 220px;
    opacity: .7;
  }
  .contact-content{
    margin-left: 140px;
  }
}

@media (max-width: 560px){
  .contact-wrap{
    min-height: 560px;
  }
  .contact-visual{
    position: static;
    transform: none;
    width: 210px;
    margin: 0 auto 18px;
  }
  .contact-content{
    margin-left: 0;
    text-align: center;
  }
  .contact-footer{
    grid-template-columns: 1fr;
    justify-items: center;
    bottom: 16px;
    gap: 8px;
  }
  .contact-lang{ justify-self: center; }
}

/* ===== FIX HERO DI MOBILE/MD BIAR GAK NABRAK (ADD-ON) ===== */
@media (max-width: 1100px){
  /* kasih ruang atas biar gak ketutup header sticky */
  .masthead-inner{
    padding: calc(var(--header-h) + 28px) 18px 56px;
  }

  /* matikan absolute agar semua teks ikut flow */
  .judul-kps,
  .fh-uner,
  .hero-copy{
    position: static !important;
    left: auto !important;
    top: auto !important;
    text-align: justify;
  }

  /* rapihin layout hero jadi vertikal */
  .judul-kps{
    margin: 0 0 10px;
    font-size: clamp(28px, 7vw, 40px);
    line-height: 1.05;
  }

  .fh-uner{
    margin: 0 0 12px;
    font-size: clamp(16px, 4.4vw, 22px);
    letter-spacing: .08em;
    line-height: 1.2;
  }

  .hero-copy{
    max-width: 52ch;
    font-size: clamp(14px, 3.8vw, 18px);
    line-height: 1.4;
    text-align: justify; /* biar rapi di mobile */
  }

  /* Responsive for Masthead Blurred */
  .masthead-blurred .masthead-inner {
    padding: 60px 24px 0; /* Dinaikkan: dari 100px ke 60px */
  }
  .masthead-blurred .judul-kps {
    text-align: left !important;
    max-width: none;
    font-size: clamp(32px, 8vw, 54px); /* Kecilkan font di mobile agar pas */
    margin-bottom: 6px; /* Lebih rapat di mobile */
  }
  .masthead-blurred .hero-copy {
    text-align: left !important;
    font-size: clamp(16px, 4vw, 20px);
  }
}

/* layar lebih kecil lagi */
@media (max-width: 520px){
  .masthead{ min-height: 520px; } /* biar background masih lega */
  .hero-copy{ max-width: 46ch; }
}

/* ===== CONTACT DESKTOP LAYOUT FIX (ADD-ON) ===== */
.contact{
  position: relative; /* biar social bisa absolute ke section */
  background: #fff;
  color: #111;
}

/* MOBILE: tetep center (pakai yang kemarin) */
@media (max-width: 720px){
  .contact, .contact-wrap{ text-align:center !important; }

  .contact-wrap{
    display:grid !important;
    grid-template-columns:1fr !important;
    place-items:center !important;
    justify-items:center !important;
    gap:14px !important;
    padding:56px 18px 40px !important;
  }

  .contact-content{
    width:min(92vw,520px) !important;
    margin:0 auto !important;
  }
  
  .contact-media{
    width:min(92vw,520px) !important;
    margin:0 auto !important;
    display:flex !important;
    justify-content:center !important;
  }

  .contact-media img{
    position: static !important;
    max-width:100% !important;
    height:auto !important;
    transform:none !important;
    display:block !important;
    margin:0 auto !important;
  }

  .contact-footer{
    width:min(92vw,520px) !important;
    margin:18px auto 0 !important;
    display:flex !important;
    justify-content:center !important;
    gap:18px !important;
  }
}

/* ===== CONTACT: ALWAYS CENTER (ADD-ON OVERRIDE) ===== */
.contact{
  /* biar section bisa center secara vertikal & horizontal */
  display: grid !important;
  place-items: center !important;

  text-align: center !important;
  padding: clamp(70px, 10vw, 140px) 0 !important;
}

.contact-wrap{
  /* jadikan layout 1 kolom & center semua anaknya */
  display: grid !important;
  grid-template-columns: 1fr !important;
  place-items: center !important;
  justify-items: center !important;
  align-content: center !important;

  width: min(1200px, 100%) !important;
  margin: 0 auto !important;
  padding: 0 18px !important;
  min-height: auto !important;
}

.contact-content{
  margin: 0 auto !important;
  text-align: center !important;
}

/* penting: footer jangan absolute, biar ikut flow dan bener-bener center */
.contact-footer{
  position: static !important;
  bottom: auto !important;

  margin-top: 24px !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

/* optional tapi aman: biar media (kalau ada) juga center */
.contact-media{
  display: flex !important;
  justify-content: center !important;
}
.contact-media img{
  margin: 0 auto !important;
  display: block !important;
}

/* ===== REMOVE FADE OVERLAY THAT LOOKS LIKE "SHADOW STUCK" ===== */
.news-carousel::before,
.news-carousel::after,
.partners-carousel::before,
.partners-carousel::after{
  display: none !important;
  content: none !important;
}
/* ===== CLEAN FADE USING MASK (OPTIONAL) ===== */
.news-carousel{
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

.partners-carousel{
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

/* CONTACT Apple-style */
.contact-logo{
  width: clamp(220px, 22vw, 280px);
  height: auto;
  margin-bottom: 18px;
}
.contact-icons{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin: 4px 0 32px;
}
.contact-app{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: #111;
  text-decoration: none;
  font-weight: 800;
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
  transition: transform 300ms cubic-bezier(.2,.8,.2,1), box-shadow 300ms cubic-bezier(.2,.8,.2,1);
}
.contact-app img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.contact-app:hover{
  transform: translateY(-4px);
  box-shadow: 0 16px 32px rgba(0,0,0,.18);
}
.app-linkedin{ background: #ffffff; }
.app-instagram{ background: #ffffff; }
.app-line{ background: #ffffff; font-weight: 700; font-size: 12px; }
.app-wa{ background: #ffffff; font-weight: 800; }
.app-email{ background: linear-gradient(180deg,#4b8df8,#2b6be6); color:#fff; }

.contact-desc{
  margin: 24px 0 4px;
  font-size: 20px;
  line-height: 1.25;
  color: #111;
  max-width: 84ch;
  font-weight: 600;
}
.contact-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  padding: 0 26px;
  border-radius: 999px;
  border: 1px solid rgba(187,41,41,.2);
  background: var(--accent);
  color: #ffffff;
  font-weight: 800;
  font-size: 16px;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 300ms cubic-bezier(.2,.8,.2,1), transform 250ms cubic-bezier(.2,.8,.2,1), box-shadow 300ms cubic-bezier(.2,.8,.2,1);
}
.contact-btn:hover{
  background: #c53333;
  box-shadow: 0 16px 24px rgba(0,0,0,.16);
  transform: translateY(-3px);
}
.contact-btn:active{
  transform: translateY(-1px) scale(.99);
}
.contact-subscribe{
  width: min(520px, 92vw);
  margin: 14px auto 0;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(6px);
  pointer-events: none;
  transition: max-height 500ms cubic-bezier(.2,.8,.2,1), opacity 400ms cubic-bezier(.2,.8,.2,1), transform 500ms cubic-bezier(.2,.8,.2,1);
}
.contact-subscribe.is-open{
  max-height: 200px;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.subscribe-form{
  display: flex;
  gap: 10px;
  justify-content: center;
  align-items: center;
  padding-top: 8px;
}
.subscribe-input{
  flex: 1 1 auto;
  min-width: 240px;
  height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.16);
  background: #ffffff;
  color: #111;
  font-size: 15px;
  outline: none;
  transition: border-color 220ms ease, box-shadow 220ms ease;
}
.subscribe-input:focus{
  border-color: #2b6be6;
  box-shadow: 0 0 0 4px rgba(43,107,230,.16);
}
.subscribe-submit{
  height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: #bb2929;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  transition: background-color 300ms cubic-bezier(.2,.8,.2,1), transform 250ms cubic-bezier(.2,.8,.2,1);
}
.subscribe-submit:hover{ background:#1a1a1a; }
.subscribe-submit:active{ transform: scale(.98); }
.contact-address{
  margin-top: -5px;
  color: #3b3b3b;
  text-decoration: none;
  font-weight: 400;
  font-size: 16px;
  border-bottom: none;
}
.contact-address:hover{ border-bottom-color: transparent; }

/* =========================================
   HOMEPAGE NEW MASTHEAD STYLE (Screenshoot)
   ========================================= */

/* Override base masthead for home */
.masthead.masthead-home {
  background: #ffffff !important;
  min-height: 90vh;
  display: flex;
  align-items: center;
  padding-top: var(--header-h);
  position: relative; /* Ensure decorations align correctly */
  overflow: hidden; /* Prevent wave bleed */
}

.masthead.masthead-home .masthead-inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  align-items: center;
  gap: 40px;
  width: 100%;
  max-width: 1200px;
  padding-top: 40px;
  padding-bottom: 120px; /* Space for wave */
}

/* Typography Overrides for Home */
.masthead.masthead-home .judul-kps,
.masthead.masthead-home .fh-uner,
.masthead.masthead-home .org-name,
.masthead.masthead-home .hero-copy {
  position: static !important;
  left: auto !important;
  top: auto !important;
  text-shadow: none !important;
  text-align: left;
  margin: 0;
}

.masthead.masthead-home .fh-uner {
  font-family: "Inter", sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #999;
  text-transform: uppercase;
  margin-bottom: 8px;
  display: block;
}

.masthead.masthead-home .org-name {
  font-family: "Inter", sans-serif;
  font-size: 24px;
  font-weight: 800;
  color: #111;
  margin-bottom: 24px;
  letter-spacing: -0.02em;
}

.masthead.masthead-home .judul-kps {
  font-family: "Inter", sans-serif;
  font-size: clamp(36px, 4.5vw, 56px);
  font-weight: 800;
  line-height: 1.15;
  color: #222;
  margin-bottom: 24px;
}

.masthead.masthead-home .judul-kps .highlight {
  color: #b81515; /* KPS Red */
  /* display: inline-block; removed to ensure flow */
  /* margin-left: 0.25em; removed, space in HTML is enough */
}

.masthead.masthead-home .hero-copy {
  font-size: 18px;
  line-height: 1.6;
  color: #555;
  max-width: 540px;
}

/* Image Container */
.hero-image-container {
  position: relative;
  width: 100%;
  max-width: 620px;
  margin-left: auto;
  min-height: 420px;
}

.hero-image-mask {
  width: clamp(150px, 18vw, 220px);
  aspect-ratio: 1;
  border-radius: 55% 45% 60% 40% / 60% 45% 55% 40%;
  overflow: hidden;
  background: #f8f8f8;
  box-shadow: 0 18px 40px rgba(0,0,0,.28);
  position: absolute;
}

.hero-image-mask img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.06);
}

.hero-image-mask--left {
  width: clamp(240px, 26vw, 310px);
  bottom: -22%;
  left: -10%;
  transform: translate(0, 8%) scale(1);
  border-radius: 70% 40% 60% 40% / 65% 45% 55% 35%;
  z-index: 3;
}

.hero-image-mask--center {
  width: clamp(260px, 26vw, 340px);
  top: -20%;
  right: -6%;
  transform: none; /* sengaja biar nabrak wave atas */
  z-index: 2;
}

.hero-image-mask--right {
  width: clamp(200px, 22vw, 260px);
  bottom: -20%;
  left: 46%;
  transform: translate(0, 10%) scale(0.98);
  border-radius: 45% 60% 55% 45% / 40% 60% 50% 60%;
  z-index: 3;
}

/* Decorative Waves */
.masthead-decoration-top {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  line-height: 0;
  z-index: 1;
  pointer-events: none;
}

.masthead-decoration-top svg {
  width: 100%;
  height: auto;
  max-height: 120px;
  display: block;
}

.masthead-decoration {
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  line-height: 0;
  z-index: 1;
  pointer-events: none;
}

.masthead-decoration svg {
  width: 100%;
  height: auto;
  max-height: 160px;
  display: block;
}

/* Responsive Home */
@media (max-width: 960px) {
  .masthead.masthead-home .masthead-inner {
    grid-template-columns: 1fr;
    text-align: center;
    padding-top: 20px;
  }
  
  .masthead.masthead-home .judul-kps,
  .masthead.masthead-home .fh-uner,
  .masthead.masthead-home .hero-copy {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }
  
  .hero-image-container {
    margin: 40px auto 0;
    max-width: 360px;
    min-height: 0;
  }

  .hero-image-mask {
    position: relative;
    width: clamp(120px, 32vw, 150px);
    transform: none;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    margin: 8px;
  }
}

/* Subscribe Success Animation */
.contact-btn.is-hidden {
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}
.contact-subscribe.is-hidden {
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}
.contact-success {
  margin: 14px auto 0;
  font-size: 20px;
  font-weight: 700;
  color: #bb2929;
  text-align: center;
  opacity: 0;
  transform: translateY(10px);
  display: none;
  transition: opacity 500ms cubic-bezier(.2,.8,.2,1), transform 500ms cubic-bezier(.2,.8,.2,1);
  position: relative;
  overflow: visible;
}
.contact-success.is-visible {
  opacity: 1;
  transform: translateY(0);
  display: block;
}

/* Splash Particles */
.success-particle {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 6px;
  height: 6px;
  background: #bb2929;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  z-index: -1;
}

@keyframes particle-explode {
  0% {
    transform: translate(-50%, -50%) scale(0.8);
    opacity: 1;
  }
  100% {
    transform: translate(calc(-50% + var(--tx)), calc(-50% + var(--ty))) scale(0);
    opacity: 0;
  }
}

/* Subscribe Success Animation */
.contact-btn.is-hidden {
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}
.contact-subscribe.is-hidden {
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}
.contact-success {
  margin: 14px auto 0;
  font-size: 20px;
  font-weight: 800;
  color: #bb2929;
  text-align: center;
  opacity: 0;
  transform: translateY(10px);
  display: none;
  transition: opacity 500ms cubic-bezier(.2,.8,.2,1), transform 500ms cubic-bezier(.2,.8,.2,1);
}
.contact-success.is-visible {
  opacity: 1;
  transform: translateY(0);
  display: block;
}

/* Subscribe Success Animation */
.contact-btn.is-hidden {
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}
.contact-subscribe.is-hidden {
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}
.contact-success {
  margin: 14px auto 0;
  font-size: 20px;
  font-weight: 800;
  color: #bb2929;
  text-align: center;
  opacity: 0;
  transform: translateY(10px);
  display: none;
  transition: opacity 500ms cubic-bezier(.2,.8,.2,1), transform 500ms cubic-bezier(.2,.8,.2,1);
}
.contact-success.is-visible {
  opacity: 1;
  transform: translateY(0);
  display: block;
}

media img{
    height: auto;
    max-height: 260px;
  }


/* =======================
   RESPONSIVE
======================= */
@media (max-width: 980px){
  .nav-toggle{ display:block; }

  .nav{
    position: absolute;
    top: var(--header-h);
    left: 0;
    right: 0;
    background:#fff;
    border-bottom: 1px solid rgba(0,0,0,.06);
    transform: translateY(-8px);
    opacity: 0;
    pointer-events: none;
    transition: .16s ease;
  }

  .site-header.nav-open .nav{
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  .nav-list{
    max-width: var(--container);
    margin: 0 auto;
    padding: 12px var(--pad-x) 18px;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .dropdown{
    position: static;
    box-shadow: none;
    border: none;
    border-radius: 0;
    padding: 0 0 8px 10px;
    opacity: 1;
    transform: none;
    pointer-events: auto;
    display: none;
    margin-top: 4px;
  }

  .has-dropdown.open .dropdown{ display:block; }

  .masthead-inner{
    padding-top: 54px;
  }
}

@media (max-width: 520px){
  .brand-word{ font-size: 18px; letter-spacing:.28em; }
  .brand-mark{ font-size: 24px; }
}

/* =========================
   SAMBUTAN KETUA (Preface-like)
========================= */
.preface{
  background: #ffffff;
  padding: 0;
  margin-top: 0; /* Memastikan tidak ada margin atas */
}

.preface-head{
  max-width: none;
  width: calc(100% - 24px);
  margin: 0 12px 10px;
  padding: 0;
  text-align: left;
}
.preface-heading{
  margin: 0;
  color: #0a0a0a;
  font-weight: 700;
  font-size: clamp(26px, 2.6vw, 34px);
  letter-spacing: .01em;
}

.preface-wrap{
  max-width: none;
  width: calc(100% - 24px);
  margin: 0 12px;
  padding: 56px 40px; /* Padding vertikal ditingkatkan untuk menambah tinggi */
  border-radius: 24px;
  background: linear-gradient(135deg, #b6acaccd, #ac2929);
  overflow: hidden;
  min-height: auto;

  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 48px; /* Gap ditingkatkan agar lebih lega */
  align-items: center; 
}

/* kartu teks (kiri) */
.preface-card{
  display: flex;
  align-items: center;
}

/* LEFT IMAGE CARD */
.preface-media{
  margin: 0;
  overflow: hidden;
  box-shadow: none;
  border-radius: 18px;
  background: transparent;
  align-self: stretch;
}

.preface-photo-card{
  border-radius: 26px;
  overflow: hidden;
  background:
    radial-gradient(1200px 600px at 50% 110%, rgba(255,255,255,.05), transparent 60%),
    linear-gradient(120deg, #ac2929 0%, #f7f7f7 80%);
  justify-self: start;
  max-height: 600px; /* Tingkatkan batas tinggi foto */
  height: auto;
}
.preface-photo-card .preface-media{ border-radius: 0; }

.preface-media img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;        
  object-position: bottom center;
}
@media (min-width: 900px){
  .preface-media img{
    transform: none;
  }
}

/* RIGHT CONTENT */
.preface-title{
  display: none;
}

.preface-text{
  color: #0a0a0a;
  font-size: clamp(15px, 1.6vw, 18px); /* Kembalikan ke ukuran yang lebih lega */
  line-height: 1.6;
  max-width: 720px;
}

.preface-text p{
  margin: 0 0 12px; /* Tambah margin antar paragraf */
  text-align: justify;
}

.preface-sign{
  margin-top: 24px; /* Tambah jarak ke tanda tangan */
  color: #0a0a0a;
  line-height: 1.2;
}
.preface-sign strong{
  display: block;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 800;
  margin-bottom: 4px;
  color: #0a0a0a; /* Warna teks diubah menjadi hitam */
}
.preface-role{
  display: block;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 600;
  opacity: .9;
  color: #0a0a0a; /* Warna teks diubah menjadi hitam */
}

/* =========================
   VARIAN UNTUK PNG ORANG TANPA BACKGROUND
   Jika PNG ketua transparan dan kamu ingin terlihat "contain" dan ada ruang,
   aktifkan class .is-transparent pada figure.
========================= */
.preface-media.is-transparent{
  background: transparent;
}

.preface-media.is-transparent img{
  object-fit: cover;
  height: 100%;
  padding: 0;
  transform: translateY(50px);
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 980px){
  .preface-heading{
    margin-left: 0;
    text-align: center;
  }
  .preface-head{
    text-align: center;
    margin: 0 auto 20px;
  }
  .preface-wrap{
    grid-template-columns: 1fr;
    padding: 30px;
    width: calc(100% - 24px);
    margin: 0 12px;
    gap: 30px;
  }

  .preface-photo-card{
    justify-self: center;
    width: 100%;
    max-width: 500px;
    min-height: 250px;
    padding-left: 0;
  }
  
  .preface-photo-card .preface-media{
    height: 100%;
  }
  .preface-photo-card .preface-media img{
    height: 100%;
    object-fit: cover;
    object-position: bottom center;
  }

  .preface-text{
    max-width: 100%;
    text-align: left;
  }
  .preface-text p {
    text-align: left;
  }
}

@media (max-width: 520px){
  .preface-wrap{
    padding: 24px 18px;
    width: calc(100% - 16px);
    margin: 0 8px;
    gap: 20px;
  }

  .preface-photo-card{
    min-height: 200px;
  }

  .preface-media{
    height: 100%;
    margin-bottom: 0;
  }
  
  .preface-content{
    margin-top: 0;
  }
}

/* ====== NAVBAR SHRINK ON SCROLL (ADD-ON ONLY) ====== */

/* animasi halus */
.site-header,
.nav-wrap,
.brand-logo,
.brand-mark,
.brand-word,
.nav-link{
  transition: all .22s ease;
}

/* saat scroll: tinggi header & padding mengecil */
.site-header.is-scrolled .nav-wrap{
  height: calc(var(--header-h) - 20px);
  padding-top: 6px;
  padding-bottom: 6px;
}

/* kecilkan logo & teks brand */
.site-header.is-scrolled .brand-logo{
  width: 54px;
  height: 54px;
}

/* geser sedikit supaya tetap rapi ketika mengecil */
.site-header.is-scrolled .brand-mark{
  transform: translateX(-4px) scale(.92);
}

.site-header.is-scrolled .brand-word{
  transform: translateX(-6px) scale(.92);
}

/* kecilkan menu */
.site-header.is-scrolled .nav-link{
  font-size: 13px;
  padding: 8px 2px;
}

/* (opsional) kasih shadow halus biar terasa “compact” */
.site-header.is-scrolled{
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
}

/* =========================
   TRI CARDS (BIG SCALE)
========================= */
.tri-cards{
  background:#fff;
  padding: 84px 0 110px;
}

.tri-wrap{
  max-width: 1800px;     /* lebih lebar biar skala mirip screenshot */
  margin: 0 auto;
  padding: 0 60px;

  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 52px;             /* jarak antar card lebih besar */
}

/* CARD BASE */
.tri-card{
  position: relative;
  overflow: hidden;
  border-radius: 26px;
  min-height: 640px; 
  box-shadow: 0 18px 34px rgba(0,0,0,.16);
  background: #ffffff;
  transform: translateY(0) scale(1);
  transition: transform 400ms cubic-bezier(.2,.8,.2,1), box-shadow 400ms cubic-bezier(.2,.8,.2,1);
  will-change: transform;
  --imgH: clamp(240px, 40%, 300px);
  cursor: pointer;
}

/* background image */
.tri-bg{
  position:absolute;
  left:0; right:0; bottom:0;
  width:100%;
  height: var(--imgH);
  object-fit: cover;
  object-position: center bottom;
  z-index: 0;
}

.tri-card:hover,
.tri-card:focus-within{
  transform: translateY(-8px) scale(1.01);
  box-shadow: 0 26px 48px rgba(0,0,0,.20);
}

.tri-card:active{
  transform: translateY(-6px) scale(1.005);
  box-shadow: 0 22px 42px rgba(0,0,0,.18);
}

/* overlay warna utama */
.tri-card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  opacity:0;
  background: none;
}

/* overlay gelap halus untuk kontras teks */
.tri-card::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background: none;
  opacity:0;
}

/* warna sesuai request */
.tri-blue{  background: linear-gradient(180deg, #9d3131, #232323); color:#ffffff; }
.tri-amber{ background: #fafafade; color:#0a0a0a; }
.tri-green{ background: linear-gradient(180deg, #0a0a0a, #222222); color:#ffffff; }

/* CONTENT */
.tri-content{
  position: relative;
  z-index:2;
  height:100%;

  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;

  padding: 26px 26px calc(var(--imgH) + 26px);
  color: inherit;
}

.tri-title{
  margin:0 0 24px;
  font-weight: 800;
  letter-spacing: .08em;
  line-height: 0.9;
  font-size: 30px;
  color: currentColor;
}

/* teks tengah (bold) */
.tri-sub{
  margin:0 0 16px;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.25;
  max-width: 28ch;
  color: currentColor;
}

/* teks bawah */
.tri-desc{
  margin:0;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.35;
  opacity: .9;
  max-width: 42ch;
  text-align: left;
  color: currentColor;
}

/* tombol */
.tri-btn{
  position: absolute;
  inset: 0;
  z-index: 4;
  display: block;
  background: transparent;
  border: 0;
  color: transparent;
  text-indent: -9999px;
  opacity: 0;
}

.tri-blue  .tri-btn{ background:#bb2929; border-color:#bb2929; }
.tri-amber .tri-btn{ background:#f29416; border-color:#f29416; }
.tri-green .tri-btn{ background:#5bd332; border-color:#5bd332; }

.tri-blue  .tri-btn:hover,
.tri-amber .tri-btn:hover,
.tri-green .tri-btn:hover{
  background:#ffffff;
  color:#505050;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 1100px){
  .tri-wrap{
    max-width: 1100px;
    padding: 0 28px;
    gap: 34px;
  }
  .tri-card{ min-height: 640px; }
  .tri-content{ padding: 82px 38px 54px; }
}

@media (max-width: 900px){
  .tri-wrap{
    grid-template-columns: 1fr;
    gap: 26px;
    padding: 0 20px;
  }
  .tri-card{ min-height: 560px; }
}

/* =========================
   NEWS SECTION (3 cards)
========================= */
.news{
  background: #ffffff;
  padding: 70px 0 90px;
}

.news-wrap{
  max-width: 2000px;
  margin: 0 auto;
  padding: 0 44px;
}

.news-title{
  margin: 0 0 40px;
  text-align: center;
  font-size: 32px;
  letter-spacing: .01em;
}

.news-title--item{
  color: #0a0a0a;
  font-weight: 700;
}

.news-title--putih{
  color: #6a6a6a;
  font-weight: 600;
}
@media (min-width: 900px){
  .news-title{
    white-space: nowrap;
  }
}
/* ===== carousel viewport ===== */
.news-carousel{
  position: relative;
  overflow: hidden;
  padding: 6px 0;
}

/* track berjalan */
.news-track{
  display: flex;
  gap: 26px;
  align-items: stretch;
  will-change: transform;
  transition: transform 600ms cubic-bezier(.2,.8,.2,1);
}

/* card */
.news-card{
  --gradStart: #0f0f0f;
  --gradEnd: #1e1e1e;
  flex: 0 0 420px;
  position: relative;
  color: #fff;
  border-radius: 26px;
  padding: 40px 32px 56px;
  background:
    radial-gradient(1000px 400px at 50% 110%, rgba(255,255,255,.08), transparent 60%),
    linear-gradient(180deg, var(--gradStart), var(--gradEnd));
  min-height: 640px;
  max-width: 508px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  overflow: visible;
}

.news-label{
  margin: 0 0 10px;
  color: rgba(255,255,255,.86);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .02em;
}

.news-head{
  margin: 0 0 6px;
  color: #ffffff;
  font-weight: 800;
  font-size: clamp(20px, 2.6vw, 28px);
  line-height: 1.05;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
  hyphens: auto;
}

.news-sub{
  margin: 6px 0 0;
  color: rgba(255,255,255,.85);
  font-size: clamp(14px, 2vw, 17px);
  font-weight: 600;
  line-height: 1.25;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
}


/* efek fade kiri-kanan biar mirip carousel modern */
.news-carousel::before,
.news-carousel::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 80px;
  z-index: 2;
  pointer-events:none;
}

.news-carousel::before{
  left:0;
  background: linear-gradient(90deg, #ffffff 0%, rgba(255,255,255,0) 100%);
}

.news-carousel::after{
  right:0;
  background: linear-gradient(270deg, #ffffff 0%, rgba(255,255,255,0) 100%);
}

/* responsive: card jadi lebih lebar relatif layar */
@media (max-width: 900px){
  .news-wrap{ padding: 0 20px; }
  .news-card{ flex-basis: min(86vw, 420px); }
}

@media (min-width: 900px){
  .news-card{
    flex: 0 0 calc((100% - 52px) / 3);
    max-width: none;
  }
}

.news-shell{
  position: relative;
}

/* viewport */
.news-carousel{
  position: relative;
  overflow: hidden;
  padding: 6px 0;
}

/* track */
.news-track{
  display: flex;
  gap: 26px;
  align-items: stretch;
  will-change: transform;
}

/* tombol panah */
.news-arrow{
  position: absolute;
  bottom: -40px;
  transform: none;
  z-index: 5;

  width: 46px;
  height: 46px;
  border-radius: 999px;

  border: 1px solid rgba(0,0,0,.12);
  background: rgba(240,240,240,.8);
  backdrop-filter: blur(8px);

  color: #111111;
  font-size: 28px;
  line-height: 1;
  display: grid;
  place-items: center;

  cursor: pointer;
  transition: background-color 220ms ease, transform 220ms ease, border-color 220ms ease;
}

.news-arrow:hover{
  background: rgba(250,250,250,1);
  border-color: rgba(0,0,0,.22);
}

.news-arrow:active{
  transform: scale(.98);
}

.news-arrow.prev{ right: 64px; }
.news-arrow.next{ right: 14px; }

/* responsive: panah agak masuk */
@media (max-width: 900px){
  .news-arrow.prev{ left: 6px; }
  .news-arrow.next{ right: 6px; }
}

/* contoh palette gradient ala apple */
.news-card:nth-child(1){ --gradStart:#0a0a0a; --gradEnd:#a4845d; }
.news-card:nth-child(2){ --gradStart:#912d2d; --gradEnd:#bf4d4d; }
.news-card:nth-child(3){ --gradStart:#af4848; --gradEnd:#222222; }
.news-card:nth-child(4){ --gradStart:#15223a; --gradEnd:#9a2828; }
.news-card:nth-child(5){ --gradStart:#0a0a0a; --gradEnd:#c33131; }
.news-card:nth-child(6){ --gradStart:#2a2a2a; --gradEnd:#3b3b3b; }
.news-card:nth-child(7){ --gradStart:#b64e36; --gradEnd:#81988b; }
.news-card:nth-child(8){ --gradStart:#5b2d2d; --gradEnd:#9a4d4d; }
.news-card:nth-child(9){ --gradStart:#0a1f3a; --gradEnd:#a0592e; }
.news-card:nth-child(10){ --gradStart:#443f49; --gradEnd:#a45151; }

/* =========================
   PARTNERS SECTION
========================= */
.partners{
  width: 100%;
}

/* BAGIAN JUDUL */
.partners-top{
  background: #ffffff;
  padding: 40px 0 20px;
  text-align: center;
}

.partners-title{
  margin: 0;
  color: #0a0a0a;
  font-weight: 800;
  font-size: clamp(26px, 2.6vw, 32px);
  letter-spacing: .01em;
}

/* grid logo sederhana */
.partners-logos{
  max-width: 1200px;
  margin: 0 auto 40px;
  padding: 0 24px;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px 32px;
  align-items: center;
  justify-items: center;
}
.partners-logos img{
  max-width: 160px;
  max-height: 48px;
  width: 100%;
  height: auto;
  object-fit: contain;
  filter: grayscale(100%);
  opacity: .85;
}
@media (max-width: 900px){
  .partners-logos{
    grid-template-columns: repeat(3, 1fr);
    gap: 18px 22px;
  }
  .partners-logos img{ max-width: 120px; max-height: 40px; }
}
@media (max-width: 560px){
  .partners-logos{ grid-template-columns: repeat(2, 1fr); }
}

/* =========================
   HOMEPAGE COLLAB CTA
========================= */
.collab-cta{
  background: #ffffff;
  padding: 64px 16px 80px;
  text-align: center;
}

.collab-inner{
  max-width: 780px;
  margin: 0 auto;
}

.collab-title{
  margin: 0 0 12px;
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: clamp(26px, 2.4vw, 32px);
  font-weight: 700;
  color: #0a0a0a;
}

.collab-subtitle{
  margin: 0 0 28px;
  font-size: 16px;
  line-height: 1.6;
  color: #4a4a4a;
}

.collab-button{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 32px;
  border-radius: 999px;
  border: none;
  background: #bb2929;
  color: #ffffff;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,.18);
  transition: transform 220ms cubic-bezier(.22,.61,.36,1), box-shadow 220ms ease, background-color 220ms ease;
}

.collab-button-icon{
  font-size: 18px;
}

.collab-button:hover{
  background: #971f1f;
  box-shadow: 0 14px 30px rgba(0,0,0,.22);
  transform: translateY(-1px);
}

.collab-button:active{
  transform: translateY(0);
  box-shadow: 0 6px 16px rgba(0,0,0,.18);
}

/* Overlay */
.collab-overlay{
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0,0,0,.6);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease-out;
  z-index: 1000;
}

.collab-overlay.is-open{
  opacity: 1;
  pointer-events: auto;
}

.collab-modal{
  position: relative;
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 24px 24px 26px;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  transform: translateY(32px);
  transition: transform 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

@media (max-width: 768px){
  .collab-modal{
    padding: 20px 18px 22px;
  }
}

.collab-overlay.is-open .collab-modal{
  transform: translateY(0);
}

.collab-modal-title{
  margin: 0 0 8px;
  font-size: 20px;
  font-weight: 700;
  color: #0a0a0a;
}

.collab-modal-desc{
  margin: 0 0 18px;
  font-size: 14px;
  color: #555555;
}

.collab-modal-close{
  position: absolute;
  top: 10px;
  right: 12px;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: none;
  background: transparent;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  color: #666666;
}

.collab-modal-close:hover{
  background: rgba(0,0,0,.06);
}

.collab-form{
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.collab-field{
  text-align: left;
}

.collab-label{
  display: block;
  margin-bottom: 4px;
  font-size: 13px;
  color: #333333;
}

.collab-input{
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.16);
  font-size: 14px;
  font-family: inherit;
  outline: none;
  transition: border-color 180ms ease, box-shadow 180ms ease;
}

.collab-input:focus{
  border-color: #bb2929;
  box-shadow: 0 0 0 3px rgba(187,41,41,.16);
}

.collab-textarea{
  resize: vertical;
  min-height: 96px;
}

.collab-submit{
  margin-top: 4px;
  width: 100%;
  height: 44px;
  border-radius: 999px;
  border: none;
  background: #bb2929;
  color: #ffffff;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: background-color 220ms ease, transform 220ms ease, box-shadow 220ms ease;
}

.collab-submit:hover{
  background: #971f1f;
  box-shadow: 0 8px 20px rgba(0,0,0,.22);
  transform: translateY(-1px);
}

.collab-submit:active{
  transform: translateY(0);
  box-shadow: 0 4px 12px rgba(0,0,0,.18);
}

body.collab-modal-open{
  overflow: hidden;
}

/* BAGIAN LOGO (MERAH) */
.partners-bar{
  background: #b81515;            /* ✅ merah (ubah sesuai yang kamu mau) */
  padding: 60px 0 60px;
}

/* viewport carousel */
.partners-carousel{
  max-width: 1500px;
  margin: 0 auto;
  padding: 0 40px;

  overflow: hidden;
  position: relative;
}

/* track berjalan */
.partners-track{
  display: flex;
  align-items: center;
  gap: 26px;
  will-change: transform;
}

/* kartu logo putih */
.partner{
  flex: 0 0 auto;

  width: 240px;                   /* skala seperti contoh */
  height: 74px;
  background: #ffffff;
  border-radius: 6px;

  display: flex;
  align-items: center;
  justify-content: center;

  box-shadow: 0 10px 18px rgba(255, 255, 255, 0.18);
}

.partner img{
  max-width: 78%;
  max-height: 60%;
  object-fit: contain;
  display: block;
}

/* fade kiri-kanan biar terasa carousel */
.partners-carousel::before,
.partners-carousel::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 90px;
  z-index: 2;
  pointer-events:none;
}

.partners-carousel::before{
  left:0;
  background: linear-gradient(90deg, #b81515 0%, rgba(184,21,21,0) 100%);
}
.partners-carousel::after{
  right:0;
  background: linear-gradient(270deg, #b81515 0%, rgba(184,21,21,0) 100%);
}

/* responsive */
@media (max-width: 900px){
  .partner{
    width: 200px;
    height: 68px;
  }
  .partners-carousel{
    padding: 0 18px;
  }
}

/* ===== FORCE NAVBAR ALWAYS ON TOP (ANTI KETIBAN LAYER) ===== */
.site-header{
  position: fixed;   /* override sticky -> fixed */
  top: 0;
  left: 0;
  right: 0;
  width: 100%;

  z-index: 9999999;
  border-bottom: 1px solid rgba(0,0,0,.10);
}

/* karena header jadi fixed, kasih ruang di atas konten */
body{
  padding-top: var(--header-h);
}

/* pas shrink: tetap rapi */
.site-header.is-scrolled{
  box-shadow: 0 12px 28px rgba(230, 81, 81, 0.14);
}

/* =========================
   CONTACT (8 Rivers-ish)
========================= */
.contact{
  background: #ffffff;
  color: #0a0a0a;
  padding: clamp(80px, 10vw, 400px) 0;
  text-align: center;
}

.contact-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 0px;

  min-height: clamp(520px, 70vh, 760px);
  position: relative;

  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-media img{
  position: static !important;   /* <- bikin dia ikut flow */
  max-width: 100% !important;
  height: auto !important;
  transform: none !important;
  display: block !important;
  margin: 0 auto !important;
}

/* konten di tengah-agak kanan seperti contoh */
.contact-content{
  width: min(900px, 92vw);
}

.contact-title{
  margin: 0 0 14px;
  font-size: clamp(48px, 6vw, 50px);
  font-weight: 800;
  letter-spacing: .01em;
  text-transform: uppercase;
  line-height: 1;
}

.contact-line{
  margin: 0 0 26px;
  font-size: 14px;
  line-height: 1.5;
  color: #3b3b3b;
}

.contact-block{
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.7;
}

.contact-link{
  color: #0a0a0a;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,.18);
  padding-bottom: 1px;
}

.contact-link:hover{
  border-bottom-color: rgba(0,0,0,.55);
}

/* footer kecil bawah */
.contact-footer{
  position: absolute;
  bottom: 180px;
  display: grid;
  align-items: center;
  font-size: 40px;
  color: #6a6a6a;
}

.contact-social{
  display: flex;
  align-items: center;
  gap: 12px;
}

.contact-ic{
  color: #6a6a6a;
  text-decoration: none;
  font-weight: 700;
  letter-spacing: .02em;
}

.contact-ic:hover{ color:#0a0a0a; }

.contact-lang{
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 8px;
}

.contact-langbtn{
  border: 0;
  background: transparent;
  color: #6a6a6a;
  font: inherit;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 8px;
}

.contact-langbtn.is-active{
  color: #0a0a0a;
  font-weight: 800;
}

.contact-langsep{ opacity: .55; }

/* =========================
   REVEAL ANIMATION (fade-up)
========================= */
.contact-reveal{
  opacity: 0;
  transform: translateY(26px);
  transition:
    opacity 600ms cubic-bezier(.2,.8,.2,1),
    transform 650ms cubic-bezier(.2,.8,.2,1);
}

.contact-reveal.is-inview{
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce){
  .contact-reveal{
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* responsive: kecilkan/geser visual */
@media (max-width: 820px){
  .contact-visual{
    left: 12px;
    width: 220px;
    opacity: .7;
  }
  .contact-content{
    margin-left: 140px;
  }
}

@media (max-width: 560px){
  .contact-wrap{
    min-height: 560px;
  }
  .contact-visual{
    position: static;
    transform: none;
    width: 210px;
    margin: 0 auto 18px;
  }
  .contact-content{
    margin-left: 0;
    text-align: center;
  }
  .contact-footer{
    grid-template-columns: 1fr;
    justify-items: center;
    bottom: 16px;
    gap: 8px;
  }
  .contact-lang{ justify-self: center; }
}

/* ===== FIX HERO DI MOBILE/MD BIAR GAK NABRAK (ADD-ON) ===== */
@media (max-width: 1100px){
  /* kasih ruang atas biar gak ketutup header sticky */
  .masthead-inner{
    padding: calc(var(--header-h) + 28px) 18px 56px;
  }

  /* matikan absolute agar semua teks ikut flow */
  .judul-kps,
  .fh-uner,
  .hero-copy{
    position: static !important;
    left: auto !important;
    top: auto !important;
    text-align: justify;
  }

  /* rapihin layout hero jadi vertikal */
  .judul-kps{
    margin: 0 0 10px;
    font-size: clamp(28px, 7vw, 40px);
    line-height: 1.05;
  }

  .fh-uner{
    margin: 0 0 12px;
    font-size: clamp(16px, 4.4vw, 22px);
    letter-spacing: .08em;
    line-height: 1.2;
  }

  .hero-copy{
    max-width: 52ch;
    font-size: clamp(14px, 3.8vw, 18px);
    line-height: 1.4;
    text-align: justify; /* biar rapi di mobile */
  }

  /* Responsive for Masthead Blurred */
  .masthead-blurred .masthead-inner {
    padding: 60px 24px 0; /* Dinaikkan: dari 100px ke 60px */
  }
  .masthead-blurred .judul-kps {
    text-align: left !important;
    max-width: none;
    font-size: clamp(32px, 8vw, 54px); /* Kecilkan font di mobile agar pas */
    margin-bottom: 6px; /* Lebih rapat di mobile */
  }
  .masthead-blurred .hero-copy {
    text-align: left !important;
    font-size: clamp(16px, 4vw, 20px);
  }
}

/* layar lebih kecil lagi */
@media (max-width: 520px){
  .masthead{ min-height: 520px; } /* biar background masih lega */
  .hero-copy{ max-width: 46ch; }
}

/* ===== CONTACT DESKTOP LAYOUT FIX (ADD-ON) ===== */
.contact{
  position: relative; /* biar social bisa absolute ke section */
  background: #fff;
  color: #111;
}

/* MOBILE: tetep center (pakai yang kemarin) */
@media (max-width: 720px){
  .contact, .contact-wrap{ text-align:center !important; }

  .contact-wrap{
    display:grid !important;
    grid-template-columns:1fr !important;
    place-items:center !important;
    justify-items:center !important;
    gap:14px !important;
    padding:56px 18px 40px !important;
  }

  .contact-content{
    width:min(92vw,520px) !important;
    margin:0 auto !important;
  }
  
  .contact-media{
    width:min(92vw,520px) !important;
    margin:0 auto !important;
    display:flex !important;
    justify-content:center !important;
  }

  .contact-media img{
    position: static !important;
    max-width:100% !important;
    height:auto !important;
    transform:none !important;
    display:block !important;
    margin:0 auto !important;
  }

  .contact-footer{
    width:min(92vw,520px) !important;
    margin:18px auto 0 !important;
    display:flex !important;
    justify-content:center !important;
    gap:18px !important;
  }
}

/* ===== CONTACT: ALWAYS CENTER (ADD-ON OVERRIDE) ===== */
.contact{
  /* biar section bisa center secara vertikal & horizontal */
  display: grid !important;
  place-items: center !important;

  text-align: center !important;
  padding: clamp(70px, 10vw, 140px) 0 !important;
}

.contact-wrap{
  /* jadikan layout 1 kolom & center semua anaknya */
  display: grid !important;
  grid-template-columns: 1fr !important;
  place-items: center !important;
  justify-items: center !important;
  align-content: center !important;

  width: min(1200px, 100%) !important;
  margin: 0 auto !important;
  padding: 0 18px !important;
  min-height: auto !important;
}

.contact-content{
  margin: 0 auto !important;
  text-align: center !important;
}

/* penting: footer jangan absolute, biar ikut flow dan bener-bener center */
.contact-footer{
  position: static !important;
  bottom: auto !important;

  margin-top: 24px !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

/* optional tapi aman: biar media (kalau ada) juga center */
.contact-media{
  display: flex !important;
  justify-content: center !important;
}
.contact-media img{
  margin: 0 auto !important;
  display: block !important;
}

/* ===== REMOVE FADE OVERLAY THAT LOOKS LIKE "SHADOW STUCK" ===== */
.news-carousel::before,
.news-carousel::after,
.partners-carousel::before,
.partners-carousel::after{
  display: none !important;
  content: none !important;
}
/* ===== CLEAN FADE USING MASK (OPTIONAL) ===== */
.news-carousel{
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

.partners-carousel{
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

/* CONTACT Apple-style */
.contact-logo{
  width: clamp(220px, 22vw, 280px);
  height: auto;
  margin-bottom: 18px;
}
.contact-icons{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin: 4px 0 32px;
}
.contact-app{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: #111;
  text-decoration: none;
  font-weight: 800;
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
  transition: transform 300ms cubic-bezier(.2,.8,.2,1), box-shadow 300ms cubic-bezier(.2,.8,.2,1);
}
.contact-app img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.contact-app:hover{
  transform: translateY(-4px);
  box-shadow: 0 16px 32px rgba(0,0,0,.18);
}
.app-linkedin{ background: #ffffff; }
.app-instagram{ background: #ffffff; }
.app-line{ background: #ffffff; font-weight: 700; font-size: 12px; }
.app-wa{ background: #ffffff; font-weight: 800; }
.app-email{ background: linear-gradient(180deg,#4b8df8,#2b6be6); color:#fff; }

.contact-desc{
  margin: 24px 0 4px;
  font-size: 20px;
  line-height: 1.25;
  color: #111;
  max-width: 84ch;
  font-weight: 600;
}
.contact-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  padding: 0 26px;
  border-radius: 999px;
  border: 1px solid rgba(187,41,41,.2);
  background: var(--accent);
  color: #ffffff;
  font-weight: 800;
  font-size: 16px;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 300ms cubic-bezier(.2,.8,.2,1), transform 250ms cubic-bezier(.2,.8,.2,1), box-shadow 300ms cubic-bezier(.2,.8,.2,1);
}
.contact-btn:hover{
  background: #c53333;
  box-shadow: 0 16px 24px rgba(0,0,0,.16);
  transform: translateY(-3px);
}
.contact-btn:active{
  transform: translateY(-1px) scale(.99);
}
.contact-subscribe{
  width: min(520px, 92vw);
  margin: 14px auto 0;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(6px);
  pointer-events: none;
  transition: max-height 500ms cubic-bezier(.2,.8,.2,1), opacity 400ms cubic-bezier(.2,.8,.2,1), transform 500ms cubic-bezier(.2,.8,.2,1);
}
.contact-subscribe.is-open{
  max-height: 200px;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.subscribe-form{
  display: flex;
  gap: 10px;
  justify-content: center;
  align-items: center;
  padding-top: 8px;
}
.subscribe-input{
  flex: 1 1 auto;
  min-width: 240px;
  height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.16);
  background: #ffffff;
  color: #111;
  font-size: 15px;
  outline: none;
  transition: border-color 220ms ease, box-shadow 220ms ease;
}
.subscribe-input:focus{
  border-color: #2b6be6;
  box-shadow: 0 0 0 4px rgba(43,107,230,.16);
}
.subscribe-submit{
  height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: #bb2929;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  transition: background-color 300ms cubic-bezier(.2,.8,.2,1), transform 250ms cubic-bezier(.2,.8,.2,1);
}
.subscribe-submit:hover{ background:#1a1a1a; }
.subscribe-submit:active{ transform: scale(.98); }
.contact-address{
  margin-top: -5px;
  color: #3b3b3b;
  text-decoration: none;
  font-weight: 400;
  font-size: 16px;
  border-bottom: none;
}
.contact-address:hover{ border-bottom-color: transparent; }
