/* Header */
.kc-header{position:sticky; top:0; z-index:50; background:rgba(255,255,255,.86); backdrop-filter:saturate(160%) blur(10px); border-bottom:1px solid var(--kc-line)}
/* Header */
.kc-header{
  position:fixed;
  top:var(--wp-admin--admin-bar--height, 0px);
  left:0;
  right:0;
  z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--kc-line);
  transform:translateY(0);
  transition:transform .24s ease, background .24s ease, box-shadow .24s ease;
  will-change:transform;
}

/* Smart header states */
.kc-header.is-scrolled{
  background:rgba(255,255,255,.94);
  box-shadow:0 10px 30px rgba(11,18,32,.10);
}
.kc-header.is-scrolled .kc-header__inner{padding:10px 0}
.kc-header--hidden{transform:translateY(calc(-100% - 10px))}
.kc-header--shown{transform:translateY(0)}

@media (prefers-reduced-motion: reduce){
  .kc-header{transition:none}
}
.kc-header__inner{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:5px 0;}
.kc-header .kc-container{padding-left:24px; padding-right:24px;}
.kc-brand{display:flex; align-items:center; gap:10px; padding:6px 0}
.kc-header__cta{display:flex; align-items:center; gap:12px}
.kc-burger{padding:10px 12px}
.kc-brand__text{font-weight:800; letter-spacing:-.02em}
.kc-nav{display:none}
.kc-nav__menu{display:flex; gap:18px; list-style:none; margin:0; padding:0; font-weight:650; color:var(--kc-slate-700)}
.kc-nav__menu > li{position:relative}
.kc-nav__menu a{display:inline-flex; align-items:center; gap:8px; padding:8px 10px; border-radius:12px}
.kc-nav__menu a:hover{text-decoration:none; background:rgba(17,141,201,.06)}
.kc-nav__menu .current-menu-item > a,
.kc-nav__menu .current-menu-ancestor > a{background:rgba(17,141,201,.10); color:var(--kc-ink)}

/* Desktop dropdown submenu */
.kc-nav__menu .sub-menu{
  list-style:none;
  margin:0;
  padding:14px 10px 10px; 
  position:absolute;
  top:100%;
  left:0;
  min-width:240px;
  background:#fff;
  border:1px solid var(--kc-line);
  border-radius:16px;
  box-shadow:var(--kc-shadow-md);
  display:none;
  z-index:60;
}

.kc-nav__menu li:hover > .sub-menu,
.kc-nav__menu li:focus-within > .sub-menu{display:grid; gap:6px}
.kc-nav__menu .sub-menu a{padding:10px 12px; width:100%; justify-content:flex-start}
.kc-nav__menu .sub-menu a:hover{background:rgba(249,178,22,.12)}

.kc-burger{display:inline-flex; flex-direction:column; gap:4px; background:transparent; border:1px solid var(--kc-line); border-radius:12px; cursor:pointer}
.kc-burger__bar{width:18px; height:2px; background:var(--kc-ink)}
.kc-mnav{border-top:1px solid var(--kc-line); background:#fff; padding:14px 0}
.kc-mnav__menu{list-style:none; margin:0; padding:0; display:grid; gap:10px; font-weight:750}
.kc-mnav__menu a{display:flex; align-items:center; justify-content:space-between; padding:10px 12px; border-radius:14px}
.kc-mnav__menu a:hover{text-decoration:none; background:rgba(17,141,201,.06)}
.kc-mnav__menu .sub-menu{list-style:none; margin:6px 0 0; padding:8px 8px 8px 14px; border-left:2px solid rgba(17,141,201,.18); display:none}
.kc-mnav__menu li.is-open > .sub-menu{display:grid; gap:6px}
.kc-mnav__menu .sub-menu a{padding:8px 10px; font-weight:650}
.kc-subtoggle{margin-left:10px; width:38px; height:38px; border-radius:12px; border:1px solid var(--kc-line); background:#fff; cursor:pointer; display:inline-flex; align-items:center; justify-content:center}
.kc-subtoggle::before{content:""; width:10px; height:10px; border-right:2px solid var(--kc-slate-500); border-bottom:2px solid var(--kc-slate-500); transform:rotate(-45deg)}
.kc-mnav__menu li.is-open > .kc-subtoggle::before{transform:rotate(45deg)}
.kc-mnav__cta{display:grid; gap:10px; margin-top:14px}
@media (min-width:980px){
  .kc-nav{display:block}
  .kc-burger{display:none}
  .kc-mnav{display:none !important}
}
@media (min-width:768px){
  .kc-header .kc-container{padding-left:28px; padding-right:28px}
}

/* Footer */
.kc-footer{background:var(--kc-ink); color:#fff; padding:60px 0 28px}
.kc-footer__grid{display:grid; gap:24px}
@media (min-width:900px){ .kc-footer__grid{grid-template-columns:1.3fr 1fr 1fr; gap:40px} }
.kc-footer__title{font-weight:800; margin:0 0 12px}
.kc-footer__desc{color:rgba(255,255,255,.78); max-width:44ch}
.kc-footer__menu{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.kc-footer__menu a{color:rgba(255,255,255,.86)}
.kc-footer__list{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.kc-footer__list a{color:rgba(255,255,255,.86)}
.kc-footer__bottom{border-top:1px solid rgba(255,255,255,.14); margin-top:28px; padding-top:18px; color:rgba(255,255,255,.72)}
.kc-social{display:flex; gap:10px; margin-top:12px}
.kc-social__a{display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:12px; background:rgba(255,255,255,.10); color:#fff}
.kc-social__a:hover{text-decoration:none; background:rgba(255,255,255,.16)}

/* Buttons */
.kc-btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; border-radius:var(--kc-r-btn); padding:12px 16px; font-weight:750; border:1px solid transparent; cursor:pointer; text-decoration:none}
.kc-btn:hover{text-decoration:none; transform:translateY(-1px)}
.kc-btn--primary{
  background:linear-gradient(180deg, #fff, var(--kc-orange-100));
  border-color:rgba(249,178,22,.55);
  color:rgba(11,18,32,.92);
  box-shadow:0 10px 30px rgba(249,178,22,.12);
}
.kc-btn--primary:hover{
  background:linear-gradient(180deg, var(--kc-orange-100), rgba(249,178,22,.35));
  border-color:rgba(249,178,22,.75);
}
.kc-btn--secondary{background:var(--kc-blue-500); color:#fff}
.kc-btn--secondary:hover{background:var(--kc-blue-600)}
.kc-btn--ghost{background:transparent; border-color:var(--kc-line); color:var(--kc-slate-700)}
.kc-btn--ghost:hover{background:#fff}
.kc-btn--lg{padding:14px 18px}
.kc-btn--sm{padding:9px 12px; border-radius:12px}

.kc-btnrow{display:flex; flex-wrap:wrap; gap:12px; margin-top:18px}

/* Badges */
.kc-badge{display:inline-flex; align-items:center; padding:6px 10px; border-radius:var(--kc-r-pill); background:var(--kc-orange-100); color:var(--kc-ink); font-weight:750; font-size:.82rem}
.kc-badge--soft{background:var(--kc-blue-100)}

/* Grids */
.kc-grid{display:grid; gap:16px}
.kc-grid--benefits{grid-template-columns:1fr; }
.kc-grid--posts{grid-template-columns:1fr}
.kc-grid--portfolio{grid-template-columns:1fr}
.kc-grid--services{grid-template-columns:1fr}
.kc-grid--demos{grid-template-columns:1fr}
.kc-grid--contactmini{grid-template-columns:1fr; gap:18px}
.kc-grid--contact{grid-template-columns:1fr; gap:18px}
@media (min-width:768px){
  .kc-grid--benefits{grid-template-columns:repeat(2,1fr)}
  .kc-grid--posts{grid-template-columns:repeat(3,1fr)}
  .kc-grid--portfolio{grid-template-columns:repeat(3,1fr)}
  .kc-grid--services{grid-template-columns:repeat(2,1fr)}
  .kc-grid--demos{grid-template-columns:repeat(2,1fr)}
  .kc-grid--contactmini{grid-template-columns:1.2fr .8fr}
  .kc-grid--contact{grid-template-columns:1.2fr .8fr}
}
@media (min-width:1024px){
  .kc-grid--services{grid-template-columns:repeat(3,1fr)}
  .kc-grid--demos{grid-template-columns:repeat(4,1fr)}
}

/* Cards */
.kc-card{background:#fff; border:1px solid var(--kc-line); border-radius:var(--kc-r-card); padding:16px; box-shadow:var(--kc-shadow-sm)}
.kc-card__cover{display:block; border-radius:14px; overflow:hidden; border:1px solid var(--kc-line); margin-bottom:12px}
.kc-card__title{font-size:1.05rem; margin:0 0 6px}
.kc-card__desc{color:var(--kc-slate-700); margin:0}

/* Hero */
.kc-hero{display:grid; gap:22px; align-items:center}
.kc-hero__left,.kc-hero__right{min-width:0}
.kc-section--hero{position:relative; overflow:visible}
.kc-section--hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(1200px 600px at 18% 10%, rgba(17,141,201,.16), transparent 55%),
    radial-gradient(900px 520px at 88% 26%, rgba(249,178,22,.22), transparent 52%),
    linear-gradient(180deg, rgba(245,247,251,.65), rgba(255,255,255,0));
  pointer-events:none;
}

/* =========================================================
   Portfolio v2 (archive + single)
   Scoped to kc-pf* classes to avoid CSS collisions.
========================================================= */

/* Archive shell */
.kc-pfHub{position:relative}
.kc-pfHub__head{margin-bottom:18px}

.kc-pfFilters{border:1px solid var(--kc-line); background:rgba(255,255,255,.78); backdrop-filter:saturate(130%) blur(10px);
  border-radius:var(--kc-r-card); padding:14px; box-shadow:var(--kc-shadow-sm); margin:18px 0 22px}
.kc-pfFilters__row{display:grid; gap:12px}
.kc-pfFilters__chips{display:flex; flex-wrap:wrap; gap:10px}
.kc-pfChip{display:inline-flex; align-items:center; padding:10px 12px; border-radius:999px; border:1px solid var(--kc-line);
  background:#fff; color:var(--kc-slate-700); font-weight:750; font-size:.9rem; line-height:1; transition:transform .18s ease, box-shadow .18s ease, background .18s ease}
.kc-pfChip:hover{text-decoration:none; transform:translateY(-1px); box-shadow:0 10px 24px rgba(17,141,201,.10)}
.kc-pfChip.is-active{background:linear-gradient(180deg, rgba(249,178,22,.26), rgba(249,178,22,.10)); border-color:rgba(249,178,22,.75); color:var(--kc-ink)}

.kc-pfFilters__search{display:flex; gap:10px; align-items:center}
.kc-pfFilters__input{flex:1; min-width:180px; padding:11px 12px; border-radius:14px; border:1px solid var(--kc-line); background:#fff}
.kc-pfFilters__meta{display:flex; align-items:center; gap:12px; margin-top:10px; color:var(--kc-slate-500); font-size:.92rem}
.kc-pfFilters__count{font-weight:750; color:var(--kc-slate-700)}
.kc-pfFilters__reset{margin-left:auto; color:var(--kc-blue-600)}

.kc-pfGrid{display:grid; gap:16px}
@media (min-width:768px){ .kc-pfFilters__row{grid-template-columns:1fr auto; align-items:start} .kc-pfGrid{grid-template-columns:repeat(3,1fr)} }
@media (min-width:1024px){ .kc-pfFilters{padding:16px} .kc-pfGrid{gap:18px} }

.kc-pfEmpty{padding:22px; border:1px dashed var(--kc-line); border-radius:var(--kc-r-card); background:rgba(245,247,251,.6)}
.kc-pfPagination{margin-top:18px}

/* Portfolio card */
.kc-pfCard{border:1px solid var(--kc-line); border-radius:var(--kc-r-card); background:#fff; box-shadow:var(--kc-shadow-sm); overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease}
.kc-pfCard:hover{transform:translateY(-2px); box-shadow:0 18px 42px rgba(15,23,42,.10); border-color:rgba(17,141,201,.25)}
.kc-pfCard__cover{display:block; position:relative; aspect-ratio:16/10; background:linear-gradient(135deg, rgba(17,141,201,.10), rgba(249,178,22,.12))}
.kc-pfCard__img{width:100%; height:100%; object-fit:cover}
.kc-pfCard__ph{position:absolute; inset:0; background:radial-gradient(700px 280px at 30% 20%, rgba(249,178,22,.25), transparent 55%),
  radial-gradient(640px 280px at 76% 56%, rgba(17,141,201,.20), transparent 52%),
  linear-gradient(180deg, rgba(245,247,251,.9), rgba(255,255,255,0))}

.kc-pfCard__body{padding:14px 14px 16px}
.kc-pfCard__meta{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:10px}
.kc-pfTag{display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; background:rgba(17,141,201,.10); color:var(--kc-blue-700); font-weight:750; font-size:.82rem; line-height:1}
.kc-pfTag--year{background:rgba(249,178,22,.18); color:var(--kc-ink)}

.kc-pfCard__title{font-size:1.05rem; margin:0 0 6px; letter-spacing:-.01em}
.kc-pfCard__title a:hover{text-decoration:none}
.kc-pfCard__client{margin:0 0 8px; color:var(--kc-slate-500); font-weight:700; font-size:.92rem}
.kc-pfCard__desc{margin:0; color:var(--kc-slate-700)}
.kc-pfCard__cta{display:flex; align-items:center; gap:8px; margin-top:14px; color:var(--kc-blue-700); font-weight:800}
.kc-pfCard__ctaArrow{transition:transform .18s ease}
.kc-pfCard:hover .kc-pfCard__ctaArrow{transform:translateX(4px)}

/* Single */
.kc-pfSingle__hero{display:grid; gap:18px; margin-bottom:18px}
.kc-pfSingle__title{max-width:20ch}
.kc-pfSingle__lead{max-width:70ch}
.kc-pfMeta{display:flex; flex-wrap:wrap; gap:10px; margin-top:10px}
.kc-pfSingle__cover{border-radius:var(--kc-r-card); overflow:hidden; border:1px solid var(--kc-line); box-shadow:0 14px 50px rgba(15,23,42,.08)}
.kc-pfSingle__coverImg{width:100%; height:auto; display:block}

.kc-pfSingle__layout{display:grid; gap:18px; margin-top:20px}
@media (min-width:1024px){ .kc-pfSingle__layout{grid-template-columns:1.6fr .8fr; align-items:start} }

.kc-pfBlock{border:1px solid var(--kc-line); background:#fff; border-radius:var(--kc-r-card); padding:16px; box-shadow:var(--kc-shadow-sm); margin-bottom:16px}
.kc-pfBlock__title{margin-bottom:10px}

.kc-pfMetrics{display:grid; gap:12px}
@media (min-width:768px){ .kc-pfMetrics{grid-template-columns:repeat(3,1fr)} }
.kc-pfMetric{border:1px solid var(--kc-line); border-radius:16px; padding:14px; background:linear-gradient(180deg, rgba(245,247,251,.7), #fff)}
.kc-pfMetric__val{font-size:1.22rem; font-weight:900; letter-spacing:-.02em}
.kc-pfMetric__lab{margin-top:6px; color:var(--kc-slate-600); font-weight:750; font-size:.92rem}

.kc-pfList{margin:0; padding-left:18px}
.kc-pfList li{margin:8px 0}
.kc-pfList--compact li{margin:6px 0}

.kc-pfChips{display:flex; flex-wrap:wrap; gap:10px}
.kc-pfChipMini{display:inline-flex; align-items:center; padding:8px 10px; border-radius:999px; border:1px solid var(--kc-line); background:#fff; font-weight:750; color:var(--kc-slate-700); font-size:.88rem}

.kc-pfDetailGrid{display:grid; gap:12px}
@media (min-width:768px){ .kc-pfDetailGrid{grid-template-columns:repeat(2,1fr)} }
.kc-pfDetail{border:1px solid var(--kc-line); border-radius:16px; padding:14px; background:rgba(245,247,251,.55)}
.kc-pfDetail__k{margin:0 0 8px; font-size:.95rem; color:var(--kc-slate-700)}
.kc-pfDetail__v{margin:0; color:var(--kc-slate-700)}

.kc-pfAsideCard{position:sticky; top:96px; border:1px solid var(--kc-line); background:#fff; border-radius:var(--kc-r-card); padding:16px; box-shadow:var(--kc-shadow-sm)}
.kc-pfAsideCard__title{margin:0 0 12px; font-size:1.05rem}
.kc-pfFacts{margin:0; padding:0}
.kc-pfFacts__row{display:grid; grid-template-columns:110px 1fr; gap:10px; padding:10px 0; border-bottom:1px solid var(--kc-line)}
.kc-pfFacts__row:last-child{border-bottom:0}
.kc-pfFacts dt{margin:0; color:var(--kc-slate-500); font-weight:800; font-size:.85rem}
.kc-pfFacts dd{margin:0; font-weight:750; color:var(--kc-slate-800)}

.kc-pfLink{color:var(--kc-blue-700); text-decoration:underline; text-decoration-thickness:2px; text-underline-offset:3px}
.kc-pfLink:hover{color:var(--kc-blue-800)}

.kc-pfAsideBlock{margin-top:14px}
.kc-pfAsideBlock__k{margin:0 0 8px; font-size:.95rem}
.kc-pfAsideCta{display:grid; gap:10px; margin-top:16px}

.kc-pfBottomCta{margin-top:24px}

@media (max-width:767px){
  .kc-pfFilters__search{flex-wrap:wrap}
  .kc-pfAsideCard{position:static}
}
.kc-section--hero > .kc-container{position:relative}


.kc-stackcards{position:relative; min-height:260px; max-width:420px; margin-left:auto}
.kc-stackcards__card{
  position:absolute; left:0; right:0;
  padding:14px 16px;
  border-radius:var(--kc-r-card);
  border:1px solid var(--kc-line);
  background:#fff;
  box-shadow:var(--kc-shadow-md);
  will-change:transform;
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  --kc-ty:0px;
  --kc-tr:0deg;
  transform:translateY(var(--kc-ty)) rotate(var(--kc-tr));
}
.kc-stackcards__card:nth-child(1){--kc-ty:0px; --kc-tr:-2deg; z-index:4}
.kc-stackcards__card:nth-child(2){--kc-ty:56px; --kc-tr:2deg; z-index:3}
.kc-stackcards__card:nth-child(3){--kc-ty:112px; --kc-tr:-1deg; z-index:2}
.kc-stackcards__card:nth-child(4){--kc-ty:168px; --kc-tr:1deg; z-index:1}

/* Default: show the service badge, hide description (so the stack looks clean) */
.kc-stackcards__card p{
  margin:0;
  max-height:0;
  opacity:0;
  overflow:hidden;
  color:var(--kc-slate-700);
  line-height:1.45;
  transition:max-height .22s ease, opacity .22s ease, margin-top .22s ease;
}

/* Active/hover/focus: lift the card + reveal description */
.kc-stackcards__card:hover,
.kc-stackcards__card:focus-visible,
.kc-stackcards__card.is-active{
  z-index:20;
  border-color:rgba(17,141,201,.35);
  box-shadow:0 18px 36px rgba(15,23,42,.14);
  transform:translateY(calc(var(--kc-ty) - 18px)) rotate(calc(var(--kc-tr) * .35)) scale(1.02);
}
.kc-stackcards__card:hover p,
.kc-stackcards__card:focus-visible p,
.kc-stackcards__card.is-active p{
  margin-top:10px;
  max-height:72px;
  opacity:1;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:3;
}

/* Stackcards animation (desktop) */
.kc-stackcards.is-anim .kc-stackcards__card{animation:kc-float 6.5s ease-in-out infinite}
.kc-stackcards.is-anim .kc-stackcards__card:nth-child(2){animation-delay:.2s}
.kc-stackcards.is-anim .kc-stackcards__card:nth-child(3){animation-delay:.4s}
.kc-stackcards.is-anim .kc-stackcards__card:nth-child(4){animation-delay:.6s}
@keyframes kc-float{
  0%,100%{transform:translateY(var(--kc-ty)) rotate(var(--kc-tr))}
  50%{transform:translateY(calc(var(--kc-ty) - 10px)) rotate(calc(var(--kc-tr) + .4deg))}
}
.kc-stackcards.is-anim .kc-stackcards__card:hover,
.kc-stackcards.is-anim .kc-stackcards__card:focus-visible,
.kc-stackcards.is-anim .kc-stackcards__card.is-active{animation:none}

@media (prefers-reduced-motion: reduce){
  .kc-stackcards.is-anim .kc-stackcards__card{animation:none}
}

/* Stackcards on mobile: horizontal swipe, compact height, tap-to-expand */
@media (max-width:979px){
  .kc-hero__right{margin-top:10px}
  .kc-stackcards{
    min-height:auto; max-width:none; margin-left:0;
    display:flex; gap:12px; overflow:auto;
    padding:4px 2px 12px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }
  .kc-stackcards__card{
    position:relative;
    left:auto; right:auto;
    min-width:88%;
    transform:none;
    scroll-snap-align:start;
  }
  .kc-stackcards__card:nth-child(1),
  .kc-stackcards__card:nth-child(2),
  .kc-stackcards__card:nth-child(3),
  .kc-stackcards__card:nth-child(4){transform:none}

  /* Always keep descriptions hidden unless active */
  .kc-stackcards__card p{max-height:0; opacity:0; margin-top:0}
  .kc-stackcards__card.is-active p{
    margin-top:10px;
    max-height:88px;
    opacity:1;
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:4;
  }

  .kc-stackcards.is-anim .kc-stackcards__card{animation:none}
}
/* Trust */
.kc-trust{display:grid; gap:12px}
@media (min-width:900px){ .kc-trust{grid-template-columns:repeat(3,1fr)} }
.kc-trust__item{border:1px solid var(--kc-line); border-radius:var(--kc-r-card); padding:14px; background:#fff}
.kc-trust__k{font-weight:800; margin:0 0 6px}
.kc-trust__v{margin:0; color:var(--kc-slate-700)}

/* Steps */
.kc-steps{list-style:none; padding:0; margin:0; display:grid; gap:12px}
@media (min-width:900px){ .kc-steps{grid-template-columns:repeat(4,1fr)} }
.kc-step{border:1px solid var(--kc-line); border-radius:var(--kc-r-card); padding:16px; background:#fff}
.kc-step h3{margin:0 0 8px; font-size:1.05rem}
.kc-step p{margin:0; color:var(--kc-slate-700)}

/* Slider */
.kc-slider__head{display:flex; justify-content:flex-end; gap:10px; margin:8px 0 14px}
.kc-iconbtn{width:42px; height:42px; border-radius:14px; border:1px solid var(--kc-line); background:#fff; cursor:pointer}
.kc-slider__viewport{overflow:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; border-radius:var(--kc-r-card)}
.kc-slider__track{display:flex; gap:14px; padding:2px}
.kc-slider__item{min-width:82%; scroll-snap-align:start}
@media (min-width:768px){ .kc-slider__item{min-width:48%} }
@media (min-width:1024px){ .kc-slider__item{min-width:32%} }

/* Accordion */
.kc-accordion{display:grid; gap:10px}
.kc-acc{border:1px solid var(--kc-line); border-radius:var(--kc-r-card); background:#fff; overflow:hidden}
.kc-acc__btn{width:100%; text-align:left; padding:16px; font-weight:800; background:transparent; border:0; cursor:pointer; display:flex; justify-content:space-between; gap:12px}
.kc-acc__panel{padding:0 30px 16px; color:var(--kc-slate-700)}
/* FAQ icon modern */
.kc-acc__icon{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.7);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 48px rgba(15,23,42,.10);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.kc-acc__icon::before{
  content:"";
  width: 10px;
  height: 10px;
  border-right: 2px solid rgba(11,18,32,.72);
  border-bottom: 2px solid rgba(11,18,32,.72);
  transform: rotate(45deg);
  transition: transform .18s ease;
}

.kc-acc__btn:hover .kc-acc__icon{
  border-color: rgba(17,141,201,.30);
  box-shadow: 0 22px 60px rgba(15,23,42,.14);
}

/* state open: chevron ke atas + sedikit naik */
.kc-acc.is-open .kc-acc__icon{
  transform: translateY(-1px);
  border-color: rgba(17,141,201,.34);
}

.kc-acc.is-open .kc-acc__icon::before{
  transform: rotate(-135deg);
}

.kc-acc{
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.kc-acc:hover{
  border-color: rgba(17,141,201,.18);
  box-shadow: 0 18px 55px rgba(15,23,42,.10);
  transform: translateY(-1px);
}
.kc-acc.is-open{
  border-color: rgba(17,141,201,.22);
  box-shadow: 0 18px 55px rgba(15,23,42,.12);
}

/* =========================================================
   FAQ CTA (mini conversion box)
   ========================================================= */
.kc-faq-cta{
  margin-top: 18px;
  padding: 18px 18px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.22);
  background:
    radial-gradient(420px 220px at 18% 20%, rgba(249,178,22,.18), transparent 60%),
    radial-gradient(420px 220px at 78% 70%, rgba(17,141,201,.14), transparent 60%),
    rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 55px rgba(15,23,42,.10);

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.kc-faq-cta__title{
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: -.01em;
}

.kc-faq-cta__desc{
  margin: 0;
  color: var(--kc-slate-700);
  font-size: 14px;
  line-height: 1.5;
  max-width: 58ch;
}

.kc-faq-cta__actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

@media (max-width: 720px){
  /* 1) Paksa CTA jadi stack: text dulu, actions di bawah */
  .kc-faq-cta{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    align-items: start !important;
  }

  .kc-faq-cta__text{
    width: 100%;
  }

  .kc-faq-cta__actions{
    width: 100%;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    justify-content: stretch !important;
  }

  .kc-faq-cta__actions .kc-btn{
    width: 100%;
    justify-content: center;
    padding-inline: 12px;
    white-space: nowrap;
  }
}
@media (max-width: 720px){
  .kc-faq-cta__actions .kc-btn{
    font-size: 14px;
    white-space: nowrap;
  }
}

/* Breadcrumbs */
.kc-breadcrumbs{margin:0 0 14px}
.kc-breadcrumbs__list{list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px; color:var(--kc-slate-500); font-size:.9rem}
.kc-breadcrumbs__item a{color:var(--kc-slate-500)}
.kc-breadcrumbs__item:not(:last-child)::after{content:"/"; margin-left:8px; color:var(--kc-line)}

/* Page head */
.kc-pagehead{margin:0 0 18px}
.kc-figure{margin:18px 0; border-radius:var(--kc-r-card); overflow:hidden; border:1px solid var(--kc-line)}
.kc-figure__img{width:100%; height:auto}

/* Quick Summary */
.kc-qs{
  border:1px solid var(--kc-line);
  border-radius:var(--kc-r-card);
  background:#fff;
  padding:0;                 /* ganti: biar padding di-handle summary/body */
  margin:16px 0;
  overflow:hidden;           /* biar radius rapi */
}

.kc-qs__details{ padding:0; margin:0; }

.kc-qs__summary{
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
  padding:14px 16px;
  user-select:none;
  list-style:none;
}
.kc-qs__summary::-webkit-details-marker{ display:none; }

.kc-qs__icon{
  margin-left:auto;
  width:34px;
  height:34px;
  border:1px solid var(--kc-line);
  border-radius:999px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  background:rgba(0,0,0,.02);
}
.kc-qs__icon::before{
  content:"";
  width:8px;
  height:8px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:rotate(45deg);              /* chevron down */
  transition:transform .18s ease;
  opacity:.75;
}
.kc-qs__details[open] .kc-qs__icon::before{
  transform:rotate(-135deg);            /* chevron up */
}

.kc-qs__body{ padding:0 16px 14px; }
.kc-qs__body p{ margin:10px 0 0; }

/* List kamu tetap dipakai, works utk ol/ul */
.kc-list{ margin:10px 0 0; padding-left:18px; }
.kc-list li{ margin:6px 0; }

/* TOC */
.kc-toc{margin:16px 0}
.kc-toc > .kc-acc{border:1px solid var(--kc-line); border-radius:var(--kc-r-card); background:#fff; overflow:hidden}
.kc-toc .kc-acc__btn{padding:14px 16px; font-weight:900;font-size:25px;margin-top:20px;}
.kc-toc__list{margin:0; padding-left:18px;font-size:20px;line-height:2;}
.kc-toc__item--lvl3{margin-left:12px}
.kc-toc__hint{margin:10px 0 0; font-size:12px; color:var(--kc-slate-500)}

/* Author */
.kc-author{display:flex; gap:14px; padding:16px;border:1px solid var(--kc-line);border-radius:var(--kc-r-card);background:#fff; margin:20px 0}
.kc-author__name{font-weight:900; margin:0 0 6px}
.kc-author__bio{margin:0; color:var(--kc-slate-700)}

/* CTA strip */
.kc-cta--strip{margin:26px 0; padding:18px; border-radius:var(--kc-r-card); background:linear-gradient(135deg, var(--kc-blue-100), #fff); border:1px solid var(--kc-line)}
.kc-cta__inner{display:flex; flex-direction:column; gap:10px; align-items:flex-start}

/* Form */
.kc-form{display:grid; gap:12px}
.kc-field label{display:block; font-weight:750; margin:0 0 6px}
.kc-field input, .kc-field select, .kc-field textarea{
  width:100%; padding:12px 12px; border-radius:14px; border:1px solid var(--kc-line);
  font:inherit; background:#fff;
}
.kc-panel{border:1px solid var(--kc-line); border-radius:var(--kc-r-card); background:#fff; padding:16px; box-shadow:var(--kc-shadow-sm)}
.kc-quote{margin:0; color:var(--kc-slate-700)}
.kc-meta{color:var(--kc-slate-500)}
.kc-alert{border-radius:14px; padding:12px 14px; border:1px solid var(--kc-line); background:#fff; margin:0 0 14px}
.kc-alert--success{border-color:rgba(17,141,201,.35); background:rgba(215,240,255,.55)}

/* =========================================================
   HOTFIX v2.1.3 â€” Hero btnrow + Stackcards desktop fan + mobile show desc
   Paste at END of assets/css/components.css
   ========================================================= */

/* 1) Mobile: tombol hero 2 kolom (sejajar) */
@media (max-width: 520px) {
  .kc-hero__left .kc-btnrow {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    align-items: stretch;
  }

  .kc-hero__left .kc-btnrow .kc-btn {
    width: 100%;
    padding: 12px 12px;
    font-size: 14px;
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

/* Extra kecil (HP 360px ke bawah) biar tetap muat 1 baris */
@media (max-width: 380px) {
  .kc-hero__left .kc-btnrow .kc-btn {
    font-size: 13px;
    padding: 11px 10px;
  }
}

/* Pastikan grid item nggak bikin text kepotong (obat klasik CSS grid overflow) */
.kc-hero__left,
.kc-hero__right {
  min-width: 0;
}

/* 2) Desktop: Stackcards jadi bentuk â€œkipas/fanâ€ supaya badge semua kebaca */
@media (min-width: 1024px) {
  .kc-stackcards {
    position: relative;
    min-height: 340px; /* kasih ruang biar semua badge gak ketutup */
    padding-top: 6px;
  }

  .kc-stackcards__card {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;

    /* collapsed look */
    min-height: 74px;
    padding: 14px 16px;
    border-radius: 16px;

    /* shadow lebih halus */
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.10);

    /* anim */
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
    will-change: transform;
  }

  /* Default: badge kelihatan, deskripsi disembunyiin */
  .kc-stackcards__card p {
    margin-top: 10px;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-height .22s ease, opacity .22s ease;
  }
}
/* =========================================================
   DESKTOP â€” Service Orb + Popover Panel
   Paste at VERY END of components.css
   ========================================================= */
.kc-orbwrap{ position: relative; }

@media (min-width: 980px){
  .kc-hero__right{
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding-right: 8px;
  }

  .kc-orb{
    position: relative;
    width: clamp(160px, 16vw, 210px);
    height: clamp(160px, 16vw, 210px);
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, .45);
    background: radial-gradient(circle at 30% 25%, rgba(255,255,255,.95), rgba(219, 234, 254, .6) 45%, rgba(254, 243, 199, .45));
    box-shadow: 0 26px 70px rgba(15, 23, 42, .10);
    cursor: pointer;
    overflow: hidden;
    display: grid;
    place-items: center;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  }

  .kc-orb:hover{
    transform: translateY(-2px);
    border-color: rgba(17,141,201,.35);
    box-shadow: 0 32px 90px rgba(15, 23, 42, .14);
  }

  .kc-orb:focus-visible{
    outline: 3px solid rgba(17,141,201,.35);
    outline-offset: 4px;
  }

  .kc-orb__glow{
    position: absolute; inset: -40%;
    background: conic-gradient(from 0deg, rgba(17,141,201,.25), rgba(250,179,48,.22), rgba(17,141,201,.25));
    filter: blur(18px);
    opacity: .75;
    animation: kc-orb-spin 8s linear infinite;
  }

  .kc-orb__label{
    position: relative;
    text-align: center;
    padding: 10px 12px;
    background: rgba(255,255,255,.65);
    border: 1px solid rgba(148, 163, 184, .35);
    border-radius: 14px;
    backdrop-filter: blur(10px);
    box-shadow: 0 12px 30px rgba(15,23,42,.08);
    color: var(--kc-ink);
  }
  .kc-orb__label strong{ display:block; font-size: 14px; }
  .kc-orb__label small{ display:block; font-size: 12px; opacity: .75; margin-top: 2px; }

  @keyframes kc-orb-spin{ to { transform: rotate(360deg); } }

  @media (prefers-reduced-motion: reduce){
    .kc-orb__glow{ animation: none; }
    .kc-orb{ transition: none; }
  }

  .kc-orbpanel{
    position: absolute;
    top: 50%;
    right: calc(100% + 14px);
    transform: translateY(-50%);
    width: min(420px, 42vw);
    max-height: 420px;
    overflow: auto;
    padding: 14px;

    border: 1px solid rgba(148, 163, 184, .35);
    border-radius: 18px;
    background: rgba(255,255,255,.70);
    backdrop-filter: blur(14px);
    box-shadow: 0 28px 90px rgba(15, 23, 42, .12);

    opacity: 0;
    visibility: hidden;
    transition: opacity .18s ease, visibility .18s ease, transform .18s ease;
  }

  .kc-orbwrap.is-open .kc-orbpanel{
    opacity: 1;
    visibility: visible;
    transform: translateY(-50%) translateX(-6px);
  }

  /* Stackcards di panel: aman, rapi */
  .kc-orbpanel .kc-stackcards{
    display: grid;
    gap: 12px;
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
  }
  .kc-orbpanel .kc-stackcards__card{
    position: relative !important;
    transform: none !important;
    animation: none !important;
    box-shadow: 0 12px 30px rgba(15, 23, 42, .08);
  }
  .kc-orbpanel .kc-stackcards__card p{
    margin-top: 10px;
    opacity: 1;
    max-height: none;
  }
}

/* Mobile tetap seperti layout kamu sekarang (kalau kamu mau panelnya always visible di mobile) */
@media (max-width: 979px){
  .kc-orb{ display:none; }
  .kc-orbpanel{ position: static; transform: none; width: auto; max-height: none; opacity: 1; visibility: visible; }
}
.kc-stackcards__card:focus-visible{
  outline: 3px solid rgba(17,141,201,.35);
  outline-offset: 3px;
}

.kc-stackcards__card--link{
  display:block;
  text-decoration:none;
  color:inherit;
}
.kc-stackcards__card--link:hover{
  border-color: rgba(17,141,201,.35);
}
@media (max-width: 979px){
  /* Paksa orb hilang total di mobile */
  .kc-orb{ display:none !important; }
  .kc-orb__label{ display:none !important; }

  /* Panel selalu tampil dan gak pakai hidden animation */
  .kc-orbpanel{
    position: static !important;
    transform: none !important;
    width: auto !important;
    max-height: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    overflow: visible !important;
  }

  /* Paksa deskripsi selalu muncul di mobile */
  .kc-stackcards__card p{
    max-height: none !important;
    opacity: 1 !important;
    margin-top: 10px !important;
    overflow: visible !important;
  }
}
/* =========================================================
   HOTFIX MOBILE â€” hide ORB button + always show descriptions
   Paste at VERY END of components.css
   ========================================================= */

@media (max-width: 979px){

  /* 1) Sembunyikan tombol orb (yang nulis "Layanan Klik untuk lihat") */
  .kc-orbwrap > button.kc-orb{
    display: none !important;
  }

  /* 2) Paksa panel tampil walaupun ada atribut hidden */
  .kc-orbwrap > .kc-orbpanel,
  .kc-orbwrap > .kc-orbpanel[hidden]{
    display: block !important;
    position: static !important;
    transform: none !important;
    width: auto !important;
    max-height: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    overflow: visible !important;
  }

  /* 3) Paksa deskripsi selalu muncul di mobile */
  .kc-orbwrap .kc-stackcards__card p{
    display: block !important;
    max-height: none !important;
    opacity: 1 !important;
    margin-top: 10px !important;
    overflow: visible !important;
  }
}

/* =========================================================
   HERO â€” Solar System Orbit (v1)
   Paste at VERY END of components.css
   ========================================================= */

@media (min-width: 980px){
  .kc-orbwrap{ position: relative; }

  /* Area orbit mengelilingi orb (matahari) */
  .kc-orbit{
    position:absolute;
    inset:0;
    pointer-events:none; /* planet yg pointer-events: auto */
  }

  /* Planet base */
  .kc-planet{
    pointer-events:auto;
    position:absolute;
    left:50%;
    top:50%;
    border:0;
    border-radius:999px;
    cursor:pointer;
    background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.95), rgba(17,141,201,.18) 55%, rgba(249,178,22,.14));
    box-shadow: 0 18px 44px rgba(15, 23, 42, .10);
    border: 1px solid rgba(148,163,184,.40);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    transform: translate(-50%, -50%);
    outline: none;
  }

  .kc-planet:hover,
  .kc-planet:focus-visible{
    border-color: rgba(17,141,201,.40);
    box-shadow: 0 22px 60px rgba(15, 23, 42, .14);
    transform: translate(-50%, -50%) scale(1.06);
  }

  /* 5 planet dengan posisi â€œacak tapi enak dilihatâ€
     trik: rotate(angle) translateX(radius) rotate(-angle) */
  .kc-planet:nth-of-type(1){
    width: 18px; height: 18px;
    transform: translate(-50%,-50%) rotate(-25deg) translateX(160px) rotate(25deg);
    opacity:.95;
  }
  .kc-planet:nth-of-type(2){
    width: 26px; height: 26px;
    transform: translate(-50%,-50%) rotate(65deg) translateX(150px) rotate(-65deg);
    opacity:.95;
  }
  .kc-planet:nth-of-type(3){
    width: 14px; height: 14px;
    transform: translate(-50%,-50%) rotate(140deg) translateX(165px) rotate(-140deg);
    opacity:.80;
    filter: saturate(.9);
  }
  .kc-planet:nth-of-type(4){
    width: 22px; height: 22px;
    transform: translate(-50%,-50%) rotate(210deg) translateX(150px) rotate(-210deg);
    opacity:.92;
  }
  .kc-planet:nth-of-type(5){
    width: 12px; height: 12px;
    transform: translate(-50%,-50%) rotate(305deg) translateX(175px) rotate(-305deg);
    opacity:.75;
  }

  /* Popover tooltip */
  .kc-orbtip{
    position:absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: min(320px, 30vw);
    z-index: 1200;
    pointer-events:auto;
  }

  .kc-orbtip__inner{
    background: rgba(255,255,255,.75);
    backdrop-filter: blur(14px);
    border: 1px solid rgba(148,163,184,.35);
    border-radius: 16px;
    padding: 12px 12px;
    box-shadow: 0 26px 80px rgba(15,23,42,.14);
  }

  .kc-orbtip__term{
    display:block;
    font-weight: 900;
    letter-spacing: -.02em;
    margin-bottom: 6px;
  }
  .kc-orbtip__desc{
    margin: 0 0 10px;
    color: var(--kc-slate-700);
    line-height: 1.45;
    font-size: .95rem;
  }

  @media (prefers-reduced-motion: reduce){
    .kc-planet{ transition:none; }
  }
}

/* Mobile: planet disembunyikan (tetap pakai panel list layanan yang sudah kamu punya) */
@media (max-width: 979px){
  .kc-orbit{ display:none !important; }
}
/* =========================================================
   HERO â€” Orbit Planets Floating (v1)
   Add after the Solar System CSS
   ========================================================= */

@media (min-width: 980px){
  @keyframes kcFloatA {
    0%   { transform: var(--kc-base) translate(0px, 0px); }
    50%  { transform: var(--kc-base) translate(8px, -10px); }
    100% { transform: var(--kc-base) translate(0px, 0px); }
  }
  @keyframes kcFloatB {
    0%   { transform: var(--kc-base) translate(0px, 0px); }
    50%  { transform: var(--kc-base) translate(-10px, 7px); }
    100% { transform: var(--kc-base) translate(0px, 0px); }
  }
  @keyframes kcFloatC {
    0%   { transform: var(--kc-base) translate(0px, 0px); }
    50%  { transform: var(--kc-base) translate(6px, 9px); }
    100% { transform: var(--kc-base) translate(0px, 0px); }
  }

  /* Base: kita simpan transform â€œposisi planetâ€ ke variable,
     lalu animasi hanya nambah translate kecil */
  .kc-planet{
    will-change: transform;
  }

  /* Simpan transform posisi tiap planet ke --kc-base */
  .kc-planet:nth-of-type(1){
    --kc-base: translate(-50%,-50%) rotate(-25deg) translateX(160px) rotate(25deg);
    transform: var(--kc-base);
    animation: kcFloatA 9.5s ease-in-out infinite;
  }
  .kc-planet:nth-of-type(2){
    --kc-base: translate(-50%,-50%) rotate(65deg) translateX(150px) rotate(-65deg);
    transform: var(--kc-base);
    animation: kcFloatB 11.5s ease-in-out infinite;
  }
  .kc-planet:nth-of-type(3){
    --kc-base: translate(-50%,-50%) rotate(140deg) translateX(165px) rotate(-140deg);
    transform: var(--kc-base);
    animation: kcFloatC 10.2s ease-in-out infinite;
  }
  .kc-planet:nth-of-type(4){
    --kc-base: translate(-50%,-50%) rotate(210deg) translateX(150px) rotate(-210deg);
    transform: var(--kc-base);
    animation: kcFloatA 12.8s ease-in-out infinite;
  }
  .kc-planet:nth-of-type(5){
    --kc-base: translate(-50%,-50%) rotate(305deg) translateX(175px) rotate(-305deg);
    transform: var(--kc-base);
    animation: kcFloatB 14.2s ease-in-out infinite;
  }

  /* Hover/focus tetap kerasa â€œangkatâ€, tanpa ngerusak animasi */
  .kc-planet:hover,
  .kc-planet:focus-visible{
    animation-play-state: paused;
    transform: var(--kc-base) translate(0px, 0px) scale(1.08);
  }

  @media (prefers-reduced-motion: reduce){
    .kc-planet{ animation:none !important; }
  }
}
/* =========================================================
   HERO â€” Orbit Rings (v1) + Breathing
   ========================================================= */

@media (min-width: 980px){
  .kc-orbit{
    position:absolute;
    inset:0;
    pointer-events:none;
  }

  /* Ring base style (tipis banget) */
  .kc-orbit::before,
  .kc-orbit::after,
  .kc-orbit__ring{
    content:"";
    position:absolute;
    left:50%;
    top:50%;
    width: 380px;      /* adjust kalau mau lebih besar/kecil */
    height: 220px;     /* bikin elips */
    border-radius: 999px;
    border: 1px solid rgba(148,163,184,.22);
    transform: translate(-50%,-50%);
    opacity: .55;
    filter: saturate(.95);
  }

  /* Ring 1 */
  .kc-orbit::before{
    transform: translate(-50%,-50%) rotate(12deg);
    animation: kcRingBreathA 8.5s ease-in-out infinite;
  }

  /* Ring 2 */
  .kc-orbit::after{
    width: 420px;
    height: 250px;
    border-color: rgba(17,141,201,.18);
    transform: translate(-50%,-50%) rotate(-18deg);
    animation: kcRingBreathB 10.5s ease-in-out infinite;
    opacity: .45;
  }

  /* Ring 3 (span) */
  .kc-orbit__ring--3{
    width: 460px;
    height: 280px;
    border-color: rgba(249,178,22,.16);
    transform: translate(-50%,-50%) rotate(35deg);
    animation: kcRingBreathC 12.5s ease-in-out infinite;
    opacity: .40;
  }

  @keyframes kcRingBreathA{
    0%,100% { transform: translate(-50%,-50%) rotate(12deg) scale(1); opacity:.55; }
    50%     { transform: translate(-50%,-50%) rotate(12deg) scale(1.02); opacity:.65; }
  }
  @keyframes kcRingBreathB{
    0%,100% { transform: translate(-50%,-50%) rotate(-18deg) scale(1); opacity:.45; }
    50%     { transform: translate(-50%,-50%) rotate(-18deg) scale(1.025); opacity:.55; }
  }
  @keyframes kcRingBreathC{
    0%,100% { transform: translate(-50%,-50%) rotate(35deg) scale(1); opacity:.40; }
    50%     { transform: translate(-50%,-50%) rotate(35deg) scale(1.03); opacity:.50; }
  }

  @media (prefers-reduced-motion: reduce){
    .kc-orbit::before,
    .kc-orbit::after,
    .kc-orbit__ring{ animation:none !important; }
  }
}

/* =========================================================
   TRUST TICKER â€” Running stats (v1)
   ========================================================= */

.kc-section--ticker .kc-container{ overflow: visible; }

.kc-trustticker{
  display: grid;
  gap: 10px;
  padding: 10px 0 0;
  padding-bottom: 50px;
}

.kc-trustticker__label{
  display: inline-flex;
  width: fit-content;
  font-weight: 700;
  font-size: .82rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--kc-slate-600);
}

.kc-trustticker__note{
  font-size: .9rem;
  color: var(--kc-slate-600);
}

.kc-marquee{
  position: relative;
  overflow: hidden;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.28);
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(10px);
  padding: 10px 0;
}

/* soft fade edges */
.kc-marquee::before,
.kc-marquee::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 64px;
  z-index: 2;
  pointer-events:none;
}
.kc-marquee::before{
  left:0;
  background: linear-gradient(to right, rgba(248,250,252,1), rgba(248,250,252,0));
}
.kc-marquee::after{
  right:0;
  background: linear-gradient(to left, rgba(248,250,252,1), rgba(248,250,252,0));
}

.kc-marquee__track{
  display:flex;
  gap: 18px;
  align-items:center;
  white-space: nowrap;
  padding: 0 18px;
  will-change: transform;
  animation: kcMarqueeMove var(--kc-marquee-dur, 28s) linear infinite;
  transform: translateX(0);
}

/* pause on hover/focus */
.kc-marquee:hover .kc-marquee__track,
.kc-marquee:focus-within .kc-marquee__track{
  animation-play-state: paused;
}

@keyframes kcMarqueeMove{
  from { transform: translateX(0); }
  to   { transform: translateX(calc(-1 * var(--kc-marquee-shift, 600px))); }
}

.kc-tick{
  display:inline-flex;
  align-items: baseline;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(255,255,255,.55);
  box-shadow: 0 12px 34px rgba(15,23,42,.08);
}

.kc-tick strong{
  font-weight: 900;
  letter-spacing: -.01em;
  color: var(--kc-slate-900);
}

.kc-tick span{
  color: var(--kc-slate-700);
}

.kc-tick em{
  font-style: normal;
  font-weight: 700;
  color: var(--kc-slate-600);
  opacity: .95;
}

/* Reduced motion: no running, just wrap */
@media (prefers-reduced-motion: reduce){
  .kc-marquee{ overflow: visible; border-radius: 16px; }
  .kc-marquee::before,
  .kc-marquee::after{ display:none; }
  .kc-marquee__track{
    animation: none !important;
    white-space: normal;
    flex-wrap: wrap;
  }
}

/* =========================================================
   HOME ABOUT â€” Connect the dots (v1)
   ========================================================= */

.kc-about{
  display:grid;
  gap: 26px;
  align-items:center;
}

@media (min-width: 980px){
  .kc-about{
    grid-template-columns: 1.05fr .95fr;
    gap: 34px;
  }
}

.kc-about__chips{
  list-style:none;
  padding:0;
  margin: 12px 0 18px;
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
}
.kc-chip{
  display:inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.22);
  font-weight: 700;
  color: var(--kc-slate-700);
}
.kc-chip{
  background: rgba(255,255,255,.17);
  border-color: rgba(148,163,184,.18);
  box-shadow: 0 8px 22px rgba(15,23,42,.05);
}
@media (max-width: 520px){
    .kc-chip{font-size: 12px}
}
/* About CTA â€” stronger secondary, NO new color */
.kc-about__cta .kc-btn--ghost{
  background: rgba(255,255,255,.55);
  border-color: var(--kc-line);
  color: var(--kc-slate-900);
  font-weight: 800;
  box-shadow: 0 14px 40px rgba(15,23,42,.08);
}

.kc-about__cta .kc-btn--ghost:hover{
  background: rgba(255,255,255,.70);
  border-color: rgba(148,163,184,.55);
  box-shadow: 0 18px 55px rgba(15,23,42,.10);
}

/* RIGHT visual */
.kc-connect{
  position:relative;
  width:100%;
  min-height: 300px;
  border: 0;
  overflow:hidden;
}

@media (min-width: 980px){
  .kc-connect{ min-height: 360px; }
}

.kc-connect__svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  z-index: 1;
  pointer-events:none;
}

.kc-connect__center{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%,-50%);
  width: 86px;
  height: 86px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.30);
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(12px);
  box-shadow: 0 26px 70px rgba(15,23,42,.12);
  z-index: 3;
  display:grid;
  place-items:center;
}

.kc-connect__logo{
  width: 65px;
  height: 65px;
  display:block;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(15,23,42,.14));
}

.kc-connect__mark{
  font-weight: 900;
  letter-spacing: -.03em;
  color: var(--kc-slate-900);
}

/* Dots */
.kc-dot{
  position:absolute;
  z-index: 4;
  border:0;
  background: transparent;
  cursor:pointer;
  padding:0;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  transform: translate(-50%,-50%);
}
.kc-dot::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.30);
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.95), rgba(17,141,201,.18) 55%, rgba(249,178,22,.12));
  box-shadow: 0 14px 40px rgba(15,23,42,.12);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.kc-dot__label{
  position:absolute;
  left: 50%;
  top: -12px;
  transform: translate(-50%,-100%);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(255,255,255,.60);
  backdrop-filter: blur(10px);
  box-shadow: 0 12px 34px rgba(15,23,42,.08);
  font-weight: 800;
  font-size: .78rem;
  color: var(--kc-slate-700);
  white-space: nowrap;
  opacity: .95;
}

/* positions (persentase biar responsif) */
.kc-dot--seo   { left: 22%; top: 26%; }
.kc-dot--ads   { left: 76%; top: 22%; }
.kc-dot--web   { left: 84%; top: 58%; }
.kc-dot--sosmed{ left: 64%; top: 82%; }
.kc-dot--vr    { left: 18%; top: 72%; }

/* Floating anim (halus) */
@keyframes kcDotFloatA { 0%,100%{ transform: translate(-50%,-50%) translate(0,0); } 50%{ transform: translate(-50%,-50%) translate(10px,-8px); } }
@keyframes kcDotFloatB { 0%,100%{ transform: translate(-50%,-50%) translate(0,0); } 50%{ transform: translate(-50%,-50%) translate(-9px,7px); } }
@keyframes kcDotFloatC { 0%,100%{ transform: translate(-50%,-50%) translate(0,0); } 50%{ transform: translate(-50%,-50%) translate(6px,10px); } }

.kc-dot--seo   { animation: kcDotFloatA 10.5s ease-in-out infinite; }
.kc-dot--ads   { animation: kcDotFloatB 12.8s ease-in-out infinite; }
.kc-dot--web   { animation: kcDotFloatC 11.4s ease-in-out infinite; }
.kc-dot--sosmed{ animation: kcDotFloatA 14.2s ease-in-out infinite; }
.kc-dot--vr    { animation: kcDotFloatB 13.4s ease-in-out infinite; }

.kc-dot:hover::before,
.kc-dot:focus-visible::before{
  transform: scale(1.08);
  border-color: rgba(17,141,201,.35);
  box-shadow: 0 18px 60px rgba(15,23,42,.14);
}

@media (prefers-reduced-motion: reduce){
  .kc-dot{ animation: none !important; }
}

/* Tooltip */
.kc-connecttip{
  position:absolute;
  z-index: 20;
  pointer-events:auto;
}

.kc-connecttip{ opacity: .98; }
.kc-connecttip__term{ display:block; font-weight: 900; margin-bottom: 6px; }
.kc-connecttip__desc{ margin:0 0 10px; color: var(--kc-slate-700); line-height: 1.45; }

/* Mobile: label bisa disimplify */
@media (max-width: 520px){
  .kc-dot__label{ display:none; }
}

/* =========================================================
   SURFACE2 â€” Background premium (v1)
   ========================================================= */

.kc-section--surface2{
  position: relative;
  overflow: hidden;
}

.kc-section--surface2::before{
  content:"";
  position:absolute;
  inset:-120px -160px;
  background:
    radial-gradient(circle at 18% 20%, rgba(17,141,201,.12), transparent 45%),
    radial-gradient(circle at 78% 28%, rgba(249,178,22,.10), transparent 46%),
    radial-gradient(circle at 60% 82%, rgba(17,141,201,.08), transparent 50%),
    radial-gradient(circle at 30% 78%, rgba(249,178,22,.06), transparent 52%);
  filter: blur(0px);
  pointer-events:none;
  z-index: 0;
}

.kc-section--surface2 .kc-container{
  position: relative;
  z-index: 1;
}
.kc-connect__svg path{
  transition: stroke .18s ease, stroke-width .18s ease;
}
@keyframes kcDashMove{
  to { stroke-dashoffset: -22; }
}
.kc-connect__svg path[stroke-dasharray]{
  stroke-dashoffset: 0;
  animation: kcDashMove 1.8s linear infinite;
}
/* Connect tooltip â€” mini bubble, no border */
.kc-connecttip__inner{
  width: min(150px, 76vw);
  padding: 8px 10px !important;
  border: 0 !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.62) !important;
  backdrop-filter: blur(18px) !important;
  box-shadow: 0 18px 55px rgba(15,23,42,.12) !important;
}

.kc-connecttip__term{
  font-size: .8rem !important;
  margin: 0 0 4px !important;
}

.kc-connecttip__desc{
  font-size: .70rem ;
  line-height: 1.2 !important;
  margin: 0 0 6px !important;
  color: var(--kc-slate-700);
}

/* tombol di tooltip jadi link kecil */
.kc-connecttip__inner .kc-btn{
  padding: 6px 10px;
  font-size: .65rem;
  border-radius: 10px !important;
}
/* Connect panel â€” clean blend */
.kc-connect{
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}
.kc-connect__center{
  border: 0 !important;
  box-shadow: 0 18px 50px rgba(15,23,42,.10) !important;
  background: rgba(255,255,255,.45) !important;
}
.kc-section--surface2{
  position: relative;
  overflow:hidden;
}
.kc-section--surface2::before{
  content:"";
  position:absolute;
  inset:-140px -180px;
  background:
    radial-gradient(circle at 18% 35%, rgba(17,141,201,.10), transparent 48%),
    radial-gradient(circle at 78% 30%, rgba(249,178,22,.08), transparent 50%),
    radial-gradient(circle at 60% 82%, rgba(17,141,201,.06), transparent 52%);
  pointer-events:none;
  z-index:0;
}
.kc-section--surface2 .kc-container{ position:relative; z-index:1; }

@media (max-width: 480px) { 
 .kc-connecttip__inner{width: min(90px, 76vw);}
 .kc-connecttip__desc{font-size: .50rem;}
 .kc-connecttip__inner .kc-btn{padding: 6px 6px;font-size: .50rem;} 
}

/* =========================================================
   BENEFITS â€” Premium cards w/ icons + hover
   Paste at VERY END of components.css
   ========================================================= */

.kc-section--benefits .kc-section-head{
  max-width: 72ch;
  margin-bottom: 18px;
}

/* Mobile: 2 kolom (2x2) */
.kc-grid--benefits{
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

/* HP kecil banget: balik 1 kolom biar aman */
@media (max-width: 360px){
  .kc-grid--benefits{
    grid-template-columns: 1fr;
  }
}

/* Desktop: 4 kolom */
@media (min-width: 1024px){
  .kc-grid--benefits{
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Benefit card modifier */
.kc-card--benefit{
  position: relative;
  padding: 18px 16px;
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.kc-card--benefit::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  background:
    radial-gradient(240px 140px at 18% 16%, rgba(17,141,201,.10), transparent 55%),
    radial-gradient(240px 140px at 82% 18%, rgba(249,178,22,.10), transparent 55%);
  opacity: 0;
  pointer-events:none;
  transition: opacity .18s ease;
}

.kc-card--benefit:hover,
.kc-card--benefit:focus-within{
  transform: translateY(-3px);
  border-color: rgba(17,141,201,.25);
  box-shadow: 0 18px 55px rgba(15, 23, 42, .12);
}

.kc-card--benefit:hover::before,
.kc-card--benefit:focus-within::before{
  opacity: 1;
}

.kc-card--benefit .kc-card__icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.65);
  box-shadow: 0 12px 30px rgba(15,23,42,.08);
  margin-bottom: 10px;
}

.kc-card--benefit .kc-card__icon svg{
  width: 22px;
  height: 22px;
  color: rgba(11,18,32,.88);
}

.kc-card--benefit .kc-card__title{
  margin: 0 0 6px;
}

.kc-card--benefit .kc-card__desc{
  margin: 0;
  color: var(--kc-slate-700);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3; /* biar rapi di grid */
  overflow: hidden;
}

/* Mobile tightening */
@media (max-width: 520px){
  .kc-card--benefit{
    padding: 16px 14px;
  }
  .kc-card--benefit .kc-card__icon{
    width: 40px;
    height: 40px;
    border-radius: 13px;
  }
  .kc-card--benefit .kc-card__desc{
    -webkit-line-clamp: 14;
  }
}
/* =========================================================
   BENEFITS â€” Proof chips (small badges under grid)
   ========================================================= */
.kc-proofchips{
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.kc-proofchip{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.28);
  background: rgba(255,255,255,.72);
  color: rgba(11,18,32,.82);
  font-size: 12.5px;
  line-height: 1;
  box-shadow: 0 10px 24px rgba(15,23,42,.07);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.kc-proofchip::before{
  content:"";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(17,141,201,.85);
  box-shadow: 0 0 0 3px rgba(17,141,201,.12);
}

.kc-proofchip:hover{
  transform: translateY(-2px);
  border-color: rgba(17,141,201,.28);
  box-shadow: 0 14px 34px rgba(15,23,42,.10);
}

@media (max-width: 520px){
  .kc-proofchips{ gap: 8px; }
  .kc-proofchip{
    padding: 7px 10px;
    font-size: 12px;
  }
}
/* =========================================================
   SERVICES SLIDER â€” Modernize
   ========================================================= */

.kc-slider{
  position: relative;
}

.kc-slider__header{
  display: flex;
  justify-content: flex-end;
  margin: 10px 0 12px;
}

.kc-slider__nav{
  display: inline-flex;
  gap: 10px;
}

/* Icon button */
.kc-iconbtn{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.75);
  box-shadow: 0 14px 34px rgba(15,23,42,.10);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, opacity .16s ease;
}
.kc-iconbtn svg{
  width: 22px;
  height: 22px;
  color: rgba(11,18,32,.88);
}
.kc-iconbtn:hover{
  transform: translateY(-2px);
  border-color: rgba(17,141,201,.28);
  box-shadow: 0 18px 48px rgba(15,23,42,.14);
}
.kc-iconbtn:active{ transform: translateY(0); }
.kc-iconbtn[disabled]{
  opacity: .45;
  cursor: not-allowed;
  transform: none;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
}
.kc-iconbtn.is-moving{
  border-color: rgba(249,178,22,.34);
}

/* Viewport */
.kc-slider__viewport{
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  padding-top: 25px;
  padding-bottom: 15px; /* ruang kecil biar shadow gak kepotong */
}

/* Hilangkan scrollbar bawah yang "jelek" */
.kc-slider__viewport::-webkit-scrollbar{ height: 0; }
.kc-slider__viewport{ scrollbar-width: none; } /* Firefox */
.kc-slider__viewport::-webkit-scrollbar-thumb{ background: transparent; }

/* Track layout */
.kc-slider__track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(260px, 1fr);
  gap: 14px;
  padding: 2px;
}

/* Card style */
.kc-card--service{
  scroll-snap-align: start;
  padding: 18px 16px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.kc-card--service:hover{
  transform: translateY(-3px);
  border-color: rgba(17,141,201,.22);
  box-shadow: 0 18px 55px rgba(15, 23, 42, .12);
}

.kc-card--service .kc-card__top{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.kc-card--service .kc-card__icon{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.70);
  box-shadow: 0 12px 28px rgba(15,23,42,.08);
}
.kc-card--service .kc-card__icon svg{
  width: 21px;
  height: 21px;
  color: rgba(11,18,32,.88);
}

.kc-card--service .kc-card__desc{
  margin: 0;
  color: var(--kc-slate-700);
  line-height: 1.45;
}

/* Tombol terlalu dekat desc â†’ kasih margin-top */
.kc-card--service .kc-card__cta{
  margin-top: 12px;
}

/* Mobile tweak */
@media (max-width: 520px){
  .kc-slider__header{ margin-top: 8px; }
  .kc-iconbtn{ width: 40px; height: 40px; border-radius: 13px; }
  .kc-slider__track{ grid-auto-columns: minmax(240px, 1fr); }
  .kc-card--service{ padding: 16px 14px; }
}
/* =========================================================
   360 SHOWCASE â€” demo cards
   ========================================================= */

.kc-section--showcase360 .kc-section-head{
  max-width: 72ch;
}

.kc-grid--demos{
  display: grid;
  gap: 14px;
  grid-template-columns: 1fr;
  margin-top: 16px;
}

@media (min-width: 768px){
  .kc-grid--demos{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }
}

/* Card as link */
.kc-card--demo{
  display: block;
  text-decoration: none;
  color: inherit;
  padding: 0;
  overflow: hidden;
  border-radius: 18px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.kc-card--demo:hover{
  transform: translateY(-3px);
  border-color: rgba(17,141,201,.22);
  box-shadow: 0 18px 55px rgba(15, 23, 42, .12);
}

/* Cover placeholder */
.kc-card--demo .kc-card__cover{
  aspect-ratio: 16 / 9;
  background:
    radial-gradient(260px 160px at 20% 25%, hsla(var(--kc-demo-h), 85%, 60%, .22), transparent 60%),
    radial-gradient(220px 140px at 78% 18%, rgba(249,178,22,.16), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.55));
  border-bottom: 1px solid rgba(148,163,184,.16);
  position: relative;
}

/* Badge 360 */
.kc-demo-badge{
  position: absolute;
  left: 14px;
  top: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.75);
  box-shadow: 0 12px 28px rgba(15,23,42,.10);
  color: rgba(11,18,32,.88);
  font-size: 12px;
  line-height: 1;
}
.kc-demo-badge svg{ width: 18px; height: 18px; }

/* Body */
.kc-card--demo .kc-card__body{
  padding: 14px 16px 16px;
  padding-top: calc(var(--kc-header-h, 0px) + var(--wp-admin--admin-bar--height, 0px));
}

.kc-card--demo .kc-card__title{
  margin: 0 0 6px;
}

.kc-card--demo .kc-card__desc{
  margin: 0;
  color: var(--kc-slate-700);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

/* Faux link row */
.kc-card--demo .kc-card__link{
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(11,18,32,.88);
  font-weight: 600;
}
.kc-card--demo .kc-card__link svg{
  width: 18px;
  height: 18px;
  transition: transform .18s ease;
}
.kc-card--demo:hover .kc-card__link svg{
  transform: translateX(2px);
}
/* =========================================================
   360 SHOWCASE â€” premium placeholder w/ mark + pattern
   ========================================================= */

.kc-card--demo .kc-card__cover{
  aspect-ratio: 16 / 9;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(148,163,184,.16);

  background:
    radial-gradient(260px 160px at 18% 30%, hsla(var(--kc-demo-h), 85%, 60%, .26), transparent 60%),
    radial-gradient(240px 160px at 82% 22%, rgba(249,178,22,.18), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.58));
}

/* Pattern halus (dot + garis) biar nggak flat */
.kc-card--demo .kc-card__cover::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(circle at 1px 1px, rgba(15,23,42,.08) 1px, transparent 1.6px);
  background-size: 16px 16px;
  opacity: .28;
  transform: rotate(-6deg);
  pointer-events:none;
}

.kc-card--demo .kc-card__cover::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg, transparent 0%, rgba(255,255,255,.55) 35%, transparent 70%);
  opacity: .35;
  pointer-events:none;
}

/* Mark besar (A45 / A50 / KC) */
.kc-demo-mark{
  position: absolute;
  left: 16px;
  bottom: 14px;
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1;
  font-size: clamp(28px, 4.2vw, 46px);
  color: rgba(11,18,32,.88);
  opacity: .92;

  /* efek â€œembossâ€ halus */
  text-shadow:
    0 1px 0 rgba(255,255,255,.85),
    0 14px 36px rgba(15,23,42,.20);
}

/* â€œstrokeâ€ tipis pakai pseudo, biar berasa premium */
.kc-demo-mark{
  -webkit-text-stroke: 1px rgba(255,255,255,.35);
}

/* Badge 360 tetap */
.kc-demo-badge{
  position: absolute;
  left: 14px;
  top: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.75);
  box-shadow: 0 12px 28px rgba(15,23,42,.10);
  color: rgba(11,18,32,.88);
  font-size: 12px;
  line-height: 1;
}
.kc-demo-badge svg{ width: 18px; height: 18px; }

/* Hover: cover lebih hidup */
.kc-card--demo:hover .kc-card__cover::after{
  opacity: .55;
}
.kc-card--demo:hover .kc-demo-mark{
  transform: translateY(-1px);
  transition: transform .18s ease;
}
/* =========================================================
   360 SHOWCASE â€” microinteraction (classy)
   ========================================================= */

.kc-card--demo .kc-card__cover::after{
  /* shine awal posisi agak kiri */
  transform: translateX(-18%) skewX(-12deg);
  transition: transform .55s ease, opacity .25s ease;
}

/* badge & mark transition default */
.kc-demo-badge,
.kc-demo-mark{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, opacity .18s ease;
}

/* Hover effect: subtle lift + shine sweep */
.kc-card--demo:hover .kc-card__cover::after{
  transform: translateX(22%) skewX(-12deg); /* sweeping */
  opacity: .65;
}

/* Badge: naik tipis + lebih â€œtegasâ€ */
.kc-card--demo:hover .kc-demo-badge{
  transform: translateY(-2px);
  border-color: rgba(17,141,201,.22);
  box-shadow: 0 16px 38px rgba(15,23,42,.14);
}

/* Mark: geser naik + sedikit â€œfocusâ€ */
.kc-card--demo:hover .kc-demo-mark{
  transform: translateY(-2px);
  opacity: .98;
}

/* Optional: hover di perangkat yang memang bisa hover (biar mobile aman) */
@media (hover: none){
  .kc-card--demo .kc-card__cover::after{
    transition: none;
    transform: none;
    opacity: .35;
  }
  .kc-demo-badge,
  .kc-demo-mark{
    transition: none;
  }
}
.kc-card--demo{ cursor: pointer; }
.kc-card--demo:focus-visible{
  outline: 3px solid rgba(17,141,201,.35);
  outline-offset: 3px;
}
/* =========================================================
   WORKFLOW â€” Steps as modern cards (2x2 mobile, 4 desktop)
   ========================================================= */

.kc-section--workflow .kc-section-head{
  max-width: 72ch;
  margin-bottom: 16px;
}

/* grid */
.kc-steps--grid{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;

  /* mobile default: 2 kolom */
  grid-template-columns: repeat(2, minmax(0, 1fr));
  counter-reset: kcStep;
}

/* HP kecil banget: 1 kolom biar aman */
@media (max-width: 360px){
  .kc-steps--grid{
    grid-template-columns: 1fr;
  }
}

/* desktop: 4 kolom */
@media (min-width: 1024px){
  .kc-steps--grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
  }
}

/* card */
.kc-step--card{
  position: relative;
  padding: 16px 14px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(255,255,255,.75);
  box-shadow: 0 12px 30px rgba(15,23,42,.08);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
  counter-increment: kcStep;
}

/* subtle highlight background */
.kc-step--card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(240px 140px at 20% 20%, rgba(17,141,201,.10), transparent 60%),
    radial-gradient(240px 140px at 85% 25%, rgba(249,178,22,.10), transparent 60%);
  opacity: 0;
  pointer-events:none;
  transition: opacity .18s ease;
}

.kc-step--card:hover{
  transform: translateY(-3px);
  border-color: rgba(17,141,201,.24);
  box-shadow: 0 18px 55px rgba(15,23,42,.12);
}

.kc-step--card:hover::before{ opacity: 1; }

/* step number badge */
.kc-step--card::after{
  content: counter(kcStep);
  position: absolute;
  top: 12px;
  right: 12px;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 12px;
  color: rgba(11,18,32,.70);
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(255,255,255,.70);
}

/* icon */
.kc-step__icon{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.70);
  box-shadow: 0 10px 26px rgba(15,23,42,.08);
  margin-bottom: 10px;
}

.kc-step__icon svg{
  width: 21px;
  height: 21px;
  color: rgba(11,18,32,.88);
}

/* text */
.kc-step__title{
  margin: 0 0 6px;
  font-size: 14.5px;
}

.kc-step__desc{
  margin: 0;
  color: var(--kc-slate-700);
  line-height: 1.45;

  /* biar rapi di 2 kolom mobile */
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 12;
  overflow: hidden;
}

@media (min-width: 768px){
  .kc-step__title{ font-size: 15px; }
  .kc-step__desc{ -webkit-line-clamp: 4; }
}
/* =========================================================
   WORKFLOW â€” mini progress line (no markup change)
   ========================================================= */

/* garis kecil default */
.kc-step--card .kc-step__icon{
  position: relative;
}

.kc-step--card .kc-step__icon::after{
  content:"";
  position:absolute;
  left: 10px;
  right: 10px;
  bottom: -8px;           /* jarak dari icon */
  height: 3px;
  border-radius: 999px;
  background: rgba(148,163,184,.25);
  overflow: hidden;
}

/* â€œfillâ€ animasi */
.kc-step--card .kc-step__icon::before{
  content:"";
  position:absolute;
  left: 10px;
  bottom: -8px;
  height: 3px;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(17,141,201,.85), rgba(249,178,22,.75));
  box-shadow: 0 8px 18px rgba(17,141,201,.18);
  transition: width .22s ease;
}

/* saat hover card: fill jalan */
.kc-step--card:hover .kc-step__icon::before{
  width: calc(100% - 20px);
}

/* sedikit â€œpopâ€ icon pas hover biar hidup, tapi tetap halus */
.kc-step--card:hover .kc-step__icon{
  transform: translateY(-1px);
  transition: transform .18s ease;
}
/* =========================================================
   TESTIMONIALS â€” premium slider cards (v1)
   Paste at VERY END of components.css
   ========================================================= */

.kc-slider--testi .kc-slider__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.kc-slider--testi .kc-slider__hint{
  margin: 0;
  color: var(--kc-slate-700);
  font-size: 14px;
}

/* Nav wrapper (biar rapih kayak layanan) */
.kc-slider--testi .kc-slider__nav{
  display:flex;
  gap: 10px;
  align-items:center;
}

/* Icon button hardening (fix icon â€œnggak kebacaâ€) */
.kc-iconbtn{
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(10px);
}
.kc-iconbtn svg{
  width: 20px;
  height: 20px;
  color: rgba(11,18,32,.88);
}
.kc-iconbtn:hover{
  border-color: rgba(17,141,201,.28);
  box-shadow: 0 18px 48px rgba(15,23,42,.14);
}
.kc-iconbtn:focus-visible{
  outline: 3px solid rgba(17,141,201,.30);
  outline-offset: 3px;
}

/* Track: bikin kartu testimoni lebih lega */
.kc-slider--testi .kc-slider__track{
  grid-auto-columns: minmax(300px, 1fr);
  gap: 16px;
}

/* Card testimonial */
.kc-card--testi{
  position: relative;
  padding: 22px 18px 18px;
  overflow: visible;
}

.kc-card--testi::before{
  content:"";
  position:absolute;
  inset: 10px 10px auto auto;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(148,163,184,.18);
  background:
    radial-gradient(16px 16px at 35% 35%, rgba(249,178,22,.22), transparent 60%),
    radial-gradient(18px 18px at 70% 65%, rgba(17,141,201,.16), transparent 62%),
    rgba(255,255,255,.55);
  box-shadow: 0 18px 44px rgba(15,23,42,.08);
  opacity: .95;
}

/* Avatar circle on top */
.kc-testi__avatar{
  position:absolute;
  left: 18px;
  top: -22px;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  font-weight: 900;
  letter-spacing: -.02em;
  color: rgba(11,18,32,.90);
  border: 1px solid rgba(148,163,184,.28);
  background:
    radial-gradient(26px 20px at 30% 30%, rgba(249,178,22,.22), transparent 70%),
    radial-gradient(26px 22px at 70% 70%, rgba(17,141,201,.18), transparent 72%),
    rgba(255,255,255,.85);
  box-shadow: 0 22px 60px rgba(15,23,42,.14);
}

/* Stars */
.kc-testi__stars{
  display:flex;
  gap: 4px;
  margin: 10px 0 10px;
  padding-left: 68px; /* biar sejajar dengan avatar */
}
.kc-testi__stars svg{
  width: 16px;
  height: 16px;
  opacity: .92;
}

/* Quote */
.kc-testi__quote{
  margin: 0 0 12px;
  color: rgba(11,18,32,.90);
  line-height: 1.55;
  padding-left: 68px;
}

/* Meta */
.kc-testi__meta{
  padding-left: 68px;
}
.kc-testi__name{
  margin: 0;
  font-weight: 900;
  letter-spacing: -.01em;
}
.kc-testi__role{
  margin: 2px 0 0;
  color: var(--kc-slate-700);
  font-size: 14px;
}

/* Hover feel */
.kc-card--testi{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-card--testi:hover{
  transform: translateY(-3px);
  border-color: rgba(17,141,201,.22);
  box-shadow: 0 18px 55px rgba(15,23,42,.12);
}

/* =========================================================
   POSTS GRID + POST CARD (premium)
   ========================================================= */

/* Desktop grid tetap rapi */
.kc-grid--posts{
  gap: 16px;
}

/* Card post feel */
.kc-card--post{
  position: relative;
  overflow: visible;
}

.kc-card--post .kc-card__link{
  display: block;
  color: inherit;
  text-decoration: none;
}

/* Cover dibuat punya "frame" supaya tidak kaku */
.kc-card--post .kc-card__cover{
  position: relative;
  margin: 0;
  border-radius: 16px;
  overflow: hidden;
  aspect-ratio: 16 / 10;
  transform: translateY(-2px);
}

/* Frame glow / depth */
.kc-card--post .kc-card__cover::before{
  content:"";
  position: absolute;
  inset: -10px;
  border-radius: 22px;
  background:
    radial-gradient(220px 160px at 18% 20%, rgba(249,178,22,.22), transparent 60%),
    radial-gradient(240px 180px at 78% 70%, rgba(17,141,201,.18), transparent 62%),
    rgba(255,255,255,.25);
  transform: translate(10px, 10px);
  filter: blur(0px);
  opacity: .95;
  z-index: 0;
}

.kc-card--post .kc-card__cover img{
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 16px;
  box-shadow: 0 22px 60px rgba(15,23,42,.14);
}

/* Badge kecil di cover */
.kc-post__badge{
  position: absolute;
  z-index: 2;
  left: 12px;
  bottom: 12px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: -.01em;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
}

/* Body spacing */
.kc-card--post .kc-card__body{
  padding: 12px 2px 2px;
}

.kc-card--post .kc-card__title{
  margin: 0 0 6px;
  line-height: 1.25;
  letter-spacing: -.01em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.kc-card--post .kc-card__meta{
  margin: 0;
  font-size: 13px;
  color: var(--kc-slate-700);
}

/* Hover: subtle lift + cover tilt */
.kc-card--post{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-card--post:hover{
  transform: translateY(-3px);
}
.kc-card--post:hover .kc-card__cover{
  transform: translateY(-4px);
}

/* =========================================================
   POSTS GRID + POST CARD (premium)
   ========================================================= */
.kc-card--post{position:relative; overflow:visible}
.kc-card--post .kc-card__link{display:block; color:inherit; text-decoration:none}

.kc-card--post .kc-card__cover{
  position: relative;
  margin: 0 0 12px;
  border-radius: 16px;
  overflow: hidden;
  border: 0;
  aspect-ratio: 16 / 10;
  transform: translateY(-2px);
}

.kc-card--post .kc-card__cover::before{
  content:"";
  position:absolute;
  inset:-10px;
  border-radius: 22px;
  background:
    radial-gradient(220px 160px at 18% 20%, rgba(249,178,22,.22), transparent 60%),
    radial-gradient(240px 180px at 78% 70%, rgba(17,141,201,.18), transparent 62%),
    rgba(255,255,255,.25);
  transform: translate(10px, 10px);
  opacity: .95;
  z-index: 0;
}

.kc-card--post .kc-card__cover img{
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  border-radius: 16px;
  border: 1px solid rgba(148,163,184,.22);
  box-shadow: 0 22px 60px rgba(15,23,42,.14);
}

.kc-card--post .kc-card__cover--placeholder{
  display:grid;
  place-items:center;
  background:
    radial-gradient(240px 180px at 20% 20%, rgba(249,178,22,.22), transparent 62%),
    radial-gradient(260px 200px at 80% 70%, rgba(17,141,201,.18), transparent 62%),
    rgba(255,255,255,.7);
  border: 1px solid rgba(148,163,184,.22);
}

.kc-cover__mark{
  position: relative;
  z-index: 1;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.75);
  box-shadow: 0 18px 48px rgba(15,23,42,.10);
  color: rgba(11,18,32,.78);
}
.kc-cover__mark svg{width:24px; height:24px}

.kc-post__badge{
  position: absolute;
  z-index: 2;
  left: 12px;
  bottom: 12px;
  font-size: 12px;
  font-weight: 800;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
}

.kc-card--post .kc-card__body{padding: 2px}
.kc-card--post .kc-card__title{
  margin: 0 0 6px;
  line-height: 1.25;
  letter-spacing: -.01em;
  display:-webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
.kc-card--post .kc-card__meta{
  margin: 0;
  font-size: 13px;
  color: var(--kc-slate-700);
}

/* hover polish */
.kc-card--post{transition: transform .18s ease}
.kc-card--post:hover{transform: translateY(-3px)}
.kc-card--post:hover .kc-card__cover{transform: translateY(-4px)}

/* =========================================================
   POSTS â€” mobile swipe horizontal
   ========================================================= */
@media (max-width: 768px){
  .kc-grid--posts{
    display: grid;
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: 78%;
    overflow-x: auto;
    gap: 14px;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .kc-grid--posts > *{scroll-snap-align: start}

  .kc-grid--posts::-webkit-scrollbar{height: 8px}
  .kc-grid--posts::-webkit-scrollbar-thumb{
    border-radius: 999px;
    background: rgba(148,163,184,.35);
  }
}
/* =========================================================
   INSIGHT / POSTS â€” Featured layout (1 big + 4 small)
   ========================================================= */

/* tombol "lihat semua insight" ke kanan + kasih jarak */
#insight .kc-section-head .kc-btnrow{
  justify-content: flex-end;
  margin-top: 10px;
  margin-bottom: 18px; /* biar nggak mepet grid */
}

/* grid featured desktop */
.kc-grid--featured{
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 16px;
  align-items: start;
}

/* posisi 1 besar + 4 kecil */
.kc-grid--featured > :nth-child(1){
  grid-column: 1 / span 2;
  grid-row: 1 / span 2;
}
.kc-grid--featured > :nth-child(2){ grid-column: 3; grid-row: 1; }
.kc-grid--featured > :nth-child(3){ grid-column: 3; grid-row: 2; }
.kc-grid--featured > :nth-child(4){ grid-column: 1; grid-row: 3; }
.kc-grid--featured > :nth-child(5){ grid-column: 2; grid-row: 3; }

/* Featured card feel */
.kc-card--post-featured .kc-card__title{
  font-size: 20px;
  line-height: 1.18;
}
.kc-card--post-featured .kc-card__desc{
  margin: 0 0 10px;
  color: var(--kc-slate-700);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Compact cards: lebih pendek biar rapih di kanan & bawah */
.kc-card--post-compact .kc-card__link{
  display: grid;
  grid-template-columns: 132px 1fr;
  gap: 12px;
  align-items: stretch;
}

.kc-card--post-compact .kc-card__cover{
  aspect-ratio: auto;
  height: 100%;
  min-height: 104px;
  border-radius: 14px;
  margin: 0;
  transform: none;
}

.kc-card--post-compact .kc-card__cover::before{
  display: none; /* biar compact tetap clean */
}

.kc-card--post-compact .kc-card__cover img{
  height: 100%;
  box-shadow: 0 18px 48px rgba(15,23,42,.10);
}

.kc-card--post-compact .kc-card__body{
  padding: 4px 2px;
}
.kc-card--post-compact .kc-card__title{
  font-size: 15px;
  margin: 0 0 6px;
  -webkit-line-clamp: 2;
}
.kc-card--post-compact .kc-post__badge{
  left: 10px;
  bottom: 10px;
  font-size: 11px;
  padding: 5px 9px;
}

/* =========================================================
   Mobile: jadi swipe (biar nggak panjang menurun)
   ========================================================= */
@media (max-width: 768px){
  .kc-grid--featured{
    display: flex;
    overflow-x: auto;
    gap: 14px;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .kc-grid--featured > *{
    flex: 0 0 82%;
    scroll-snap-align: start;
  }

  /* featured sedikit lebih lebar biar kerasa hero */
  .kc-grid--featured > :first-child{
    flex-basis: 92%;
  }

  /* reset positioning (nth-child grid) */
  .kc-grid--featured > :nth-child(1),
  .kc-grid--featured > :nth-child(2),
  .kc-grid--featured > :nth-child(3),
  .kc-grid--featured > :nth-child(4),
  .kc-grid--featured > :nth-child(5){
    grid-column: auto;
    grid-row: auto;
  }

  /* compact di mobile balik ke vertical biar nggak sempit */
  .kc-card--post-compact .kc-card__link{
    grid-template-columns: 1fr;
  }
  .kc-card--post-compact .kc-card__cover{
    min-height: 0;
    aspect-ratio: 16 / 10;
  }

  .kc-grid--featured::-webkit-scrollbar{ height: 8px; }
  .kc-grid--featured::-webkit-scrollbar-thumb{
    border-radius: 999px;
    background: rgba(148,163,184,.35);
  }
}
/* =========================================================
   INSIGHT â€” Featured layout (Top: 1 big + 2 small, Bottom: 2 small)
   ========================================================= */

/* tombol lihat semua insight: kanan + jarak */
#insight .kc-section-head .kc-btnrow{
  justify-content: flex-end;
  margin-top: 10px;
  margin-bottom: 22px; /* biar nggak mepet grid */
}

/* layout wrapper */
.kc-posts-layout{}

/* top area */
.kc-posts-top{
  display: grid;
  grid-template-columns: 1.65fr 1fr;
  gap: 16px;
  align-items: stretch;
}

.kc-posts-side{
  display: grid;
  gap: 16px;
}

/* bottom area: 2 kolom */
.kc-posts-bottom{
  margin-top: 16px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

/* =========================================================
   Featured cover: lebih pendek (biar gak â€œkebesaranâ€)
   ========================================================= */
.kc-card--post-featured .kc-card__cover{
  aspect-ratio: 16 / 11; /* lebih pendek dari 16/9 */
  border-radius: 18px;
}

/* title + excerpt lebih ringkas */
.kc-card--post-featured .kc-card__title{
  font-size: 19px;
  line-height: 1.18;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.kc-card--post-featured .kc-card__desc{
  margin: 0 0 10px;
  color: var(--kc-slate-700);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 2; /* dipendekin biar gak tinggi */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Overlay gradient + CTA */
/* Overlay lebih terang, cuma kasih â€œpolishâ€ bukan gelapin */
.kc-card--post-featured .kc-post__overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(to top, rgba(255,255,255,.40), rgba(255,255,255,0) 55%),
    radial-gradient(320px 220px at 18% 20%, rgba(249,178,22,.10), transparent 60%),
    radial-gradient(340px 240px at 80% 70%, rgba(17,141,201,.08), transparent 62%);
}

/* CTA pill: putih, teks gelap (nyatu sama style situs) */
.kc-card--post-featured .kc-post__cta{
  position: absolute;
  z-index: 3;
  right: 12px;
  bottom: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 900;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  color: rgba(11,18,32,.86);
  box-shadow: 0 18px 48px rgba(15,23,42,.14);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.kc-card--post-featured .kc-post__cta svg{
  width: 16px;
  height: 16px;
}

.kc-card--post-featured:hover .kc-post__cta{
  transform: translateY(-1px);
  border-color: rgba(17,141,201,.28);
  box-shadow: 0 22px 60px rgba(15,23,42,.16);
}
/* =========================================================
   Compact cards tetap rapi (kecil kanan & bawah)
   ========================================================= */
.kc-card--post-compact .kc-card__link{
  display: grid;
  grid-template-columns: 132px 1fr;
  gap: 12px;
  align-items: stretch;
}

.kc-card--post-compact .kc-card__cover{
  height: 100%;
  min-height: 104px;
  border-radius: 14px;
  margin: 0;
  transform: none;
}
.kc-card--post-compact .kc-card__cover::before{ display:none; }

/* =========================================================
   Mobile: semua card jadi swipe (nggak panjang turun)
   ========================================================= */
@media (max-width: 768px){
  .kc-posts-layout{
    display: flex;
    overflow-x: auto;
    gap: 14px;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  /* bikin struktur inner "melebur" jadi item flex */
  .kc-posts-top,
  .kc-posts-side,
  .kc-posts-bottom{
    display: contents;
  }

  .kc-posts-layout .kc-card--post{
    flex: 0 0 82%;
    scroll-snap-align: start;
  }
  .kc-posts-layout .kc-card--post-featured{
    flex-basis: 92%;
  }

  /* compact balik vertical biar gak sempit */
  .kc-card--post-compact .kc-card__link{
    grid-template-columns: 1fr;
  }
  .kc-card--post-compact .kc-card__cover{
    min-height: 0;
    aspect-ratio: 16 / 10;
  }

  .kc-posts-layout::-webkit-scrollbar{ height: 8px; }
  .kc-posts-layout::-webkit-scrollbar-thumb{
    border-radius: 999px;
    background: rgba(148,163,184,.35);
  }
}

/* Kunci utama: jangan stretch isi kolom kanan */
.kc-posts-top{
  align-items: start; /* bukan stretch */
}

.kc-posts-side{
  align-content: start;        /* stop row stretch */
  grid-auto-rows: max-content; /* row tinggi sesuai konten */
}
.kc-card--post-compact{
  height: auto;
}
.kc-card--post-compact .kc-card__link{
  align-items: start; /* body gak ikut ketarik tinggi */
}
.kc-card--post-featured{
  background: rgba(255,255,255,.92);
}
.kc-card--post-featured .kc-post__cta{
  opacity: 0;
  transform: translateY(2px);
}
.kc-card--post-featured:hover .kc-post__cta{
  opacity: 1;
  transform: translateY(-1px);
}
/* =========================================================
   INSIGHT â€” Mobile tuning (bigger cover + better spacing)
   ========================================================= */
@media (max-width: 520px){

  /* kasih napas atas di section insight */
  #insight{
    padding-top: 28px;
  }

  /* spacing heading/lead + tombol */
  #insight .kc-section-head{
    margin-bottom: 14px;
  }

  #insight .kc-section-head .kc-btnrow{
    margin-top: 14px;
    margin-bottom: 16px;
  }

  /* featured card: cover lebih tinggi biar gak â€œkecilâ€ */
  .kc-card--post-featured .kc-card__cover{
    aspect-ratio: 16 / 11;   /* sebelumnya terlalu pendek */
    border-radius: 18px;
  }

  /* pastikan gambar memenuhi cover */
  .kc-card--post-featured .kc-card__cover img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  /* badge jangan nutup area penting */
  .kc-card--post-featured .kc-post__badge{
    left: 12px;
    bottom: 12px;
  }

  /* CTA â€œBacaâ€ jangan terlalu mepet kanan bawah */
  .kc-card--post-featured .kc-post__cta{
    right: 12px;
    bottom: 12px;
  }
}
.kc-card--post-featured .kc-card__cover img{
  object-position: 30% 50%;
}
/* Contact section layout */
.kc-grid--contactmini{
  align-items: start; /* penting: panel gak ikut stretch setinggi form */
}

/* Panel mini revamp */
.kc-panel--mini{
  align-self: start;
  padding: 18px;
  background:
    radial-gradient(520px 220px at 10% 10%, rgba(17,141,201,.10), transparent 60%),
    radial-gradient(520px 220px at 90% 30%, rgba(249,178,22,.12), transparent 62%),
    #fff;
}

.kc-panel__top .kc-h3{ margin: 0 0 6px; }
.kc-panel__top .kc-meta{ margin: 0; }

.kc-list--ticks{
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
}
.kc-list--ticks li{
  position: relative;
  padding-left: 26px;
  margin: 10px 0;
  color: var(--kc-slate-700);
  line-height: 1.45;
}
.kc-list--ticks li::before{
  content:"";
  position:absolute;
  left:0; top:2px;
  width:18px; height:18px;
  border-radius: 8px;
  border: 1px solid rgba(17,141,201,.22);
  background: rgba(17,141,201,.10);
}
.kc-list--ticks li::after{
  content:"";
  position:absolute;
  left:6px; top:7px;
  width:7px; height:4px;
  border-left:2px solid rgba(11,18,32,.70);
  border-bottom:2px solid rgba(11,18,32,.70);
  transform: rotate(-45deg);
}

.kc-panel__actions{
  display:flex;
  gap:10px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.kc-panel__note{
  margin: 12px 0 0;
}
.kc-hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.kc-captcha input{ max-width: 180px; }
/* =========================================
   Trustticker follows Hero background
   ========================================= */

/* Kalau trustticker ada di bawah hero, biar terasa satu blok */
.kc-section--ticker{
  position: relative;
  overflow: hidden;
  background:white
}

/* optional: halusin transisi atas agar nyatu dengan hero */
.kc-section--ticker::before{
  content:"";
  position:absolute;
  left:0; right:0; top:-1px;
  background: white
}
/* Footer list with icons */
.kc-footer__link{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}

.kc-ico{
  width:34px;
  height:34px;
  border-radius:14px;
  display:grid;
  place-items:center;
  color:#fff;
  background:linear-gradient(135deg, rgba(17,141,201,.35), rgba(249,178,22,.32));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  flex:0 0 auto;
}

.kc-footer__link:hover .kc-ico{
  transform:translateY(-1px);
  box-shadow:0 14px 30px rgba(0,0,0,.22);
}

/* Social icon buttons */
.kc-social{
  display:flex;
  gap:10px;
  margin-top:14px;
}

.kc-social__a{
  width:38px;
  height:38px;
  border-radius:14px;
  display:grid;
  place-items:center;
  color:#fff;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  text-decoration:none;
}

.kc-social__a:hover{
  background:linear-gradient(135deg, rgba(17,141,201,.35), rgba(249,178,22,.32));
  transform:translateY(-1px);
}

/* Visually hidden text for a11y */
.kc-sr{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
/* WP Custom Logo */
.kc-brand .custom-logo-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
}

.kc-brand .custom-logo{
  width:auto;
  height:72px;        /* header size */
  max-height:120px;
}

.kc-footer .kc-brand .custom-logo{
  height:72px;        /* footer slightly bigger */
  max-height:120px;
}
/* =========================
   KC ABOUT PAGE PACK v2.2
   (wajib ditaruh setelah CSS global lama)
========================= */

/* Section head helper (kalau belum ada) */
.kc-section-head{margin:0 0 18px}
.kc-section-head .kc-lead{margin:8px 0 0}

/* -------------------------
   HERO
------------------------- */
.kc-about-hero{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(900px 420px at 18% 10%, rgba(17,141,201,.14), rgba(255,255,255,0)),
    radial-gradient(700px 320px at 82% 14%, rgba(249,178,22,.16), rgba(255,255,255,0)),
    linear-gradient(180deg, rgba(245,249,255,.96), rgba(255,255,255,.88));
}
.kc-about-hero__grid{
  display:grid;
  gap:18px;
  align-items:start;
}
@media (min-width:900px){
  .kc-about-hero__grid{
    grid-template-columns: 1.25fr .75fr;
    gap:24px;
  }
}

/* mini panel */
.kc-mini{
  background:#fff;
  border:1px solid var(--kc-line);
  border-radius: var(--kc-r-card);
  padding:16px;
  box-shadow: var(--kc-shadow-sm);
}
.kc-mini__kicker{margin:0 0 8px; font-weight:800; color:var(--kc-slate-500); font-size:.85rem}
.kc-mini__title{margin:0 0 8px; font-weight:900}
.kc-mini__desc{margin:0; color:var(--kc-slate-700)}

/* hover sopan */
.kc-about-hero__panel .kc-mini{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-about-hero__panel .kc-mini:hover{
  transform: translateY(-2px);
  border-color: rgba(17,141,201,.18);
  box-shadow: 0 22px 55px rgba(15,23,42,.10);
}

/* btn row mobile 1 baris (2 kolom) */
@media (max-width:520px){
  .kc-btnrow--about,
  .kc-btnrow--about-cta{
    display:grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap:10px;
  }
  .kc-btnrow--about .kc-btn,
  .kc-btnrow--about-cta .kc-btn{
    width:100%;
    padding:10px 10px;
    font-size:.80rem;
    border-radius: 14px;
  }
}

/* -------------------------
   WHY
------------------------- */
.kc-about-why{background:#fff !important;}
.kc-about-why__grid{
  display:grid;
  gap:12px;
}
@media (min-width:900px){
  .kc-about-why__grid{grid-template-columns: repeat(3, minmax(0,1fr)); gap:14px;}
}

/* Swipe mobile (scroll snap) */
@media (max-width:720px){
  .kc-about-why__grid.kc-swipe{
    grid-auto-flow: column;
    grid-auto-columns: 86%;
    overflow-x:auto;
    padding-bottom: 6px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }
  .kc-about-why__grid.kc-swipe > *{scroll-snap-align:start;}
}

/* WHY cards icon badge */
.kc-whycard{position:relative; padding-top:52px;}
.kc-whycard:before{
  content:"";
  position:absolute; top:14px; left:14px;
  width:36px; height:36px; border-radius:14px;
  background: linear-gradient(135deg, rgba(17,141,201,.22), rgba(249,178,22,.18));
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 10px 24px rgba(15,23,42,.08);
}
.kc-whycard--problem:after,
.kc-whycard--impact:after,
.kc-whycard--solution:after{
  position:absolute; top:22px; left:26px;
  font-size:16px; font-weight:900; color: rgba(15,23,42,.78);
  content:"";
}
.kc-whycard--problem:after{content:"📑";}
.kc-whycard--impact:after{content:"📉";}
.kc-whycard--solution:after{content:"🛠";}

.kc-whycard{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-whycard:hover{
  transform: translateY(-3px);
  border-color: rgba(17,141,201,.18);
  box-shadow: 0 22px 55px rgba(15,23,42,.10);
}

/* -------------------------
   CONSTELLATION (DESKTOP)
------------------------- */
.kc-about-constellation{background: var(--kc-surface-2);}

/* desktop constellation canvas */
.kc-constellation{
  position:relative;
  border-radius: 22px;
  border: 1px solid rgba(15,23,42,.08);
  background:
    radial-gradient(900px 420px at 20% 20%, rgba(17,141,201,.10), rgba(255,255,255,0)),
    radial-gradient(800px 380px at 80% 30%, rgba(249,178,22,.12), rgba(255,255,255,0)),
    linear-gradient(180deg, rgba(255,255,255,.90), rgba(245,247,251,.86));
  box-shadow: 0 18px 50px rgba(15,23,42,.08);
  overflow:hidden;
  min-height: 420px;
  padding: 22px;
}

/* svg lines overlay */
.kc-constellation__lines{
  position:absolute; inset:0;
  width:100%; height:100%;
  pointer-events:none;
  opacity:.95;
}
.kc-line{
  stroke: rgba(148,163,184,.25);
  stroke-width:1.2;
  stroke-linecap:round;
  filter: url(#kcGlow);
  opacity:.95;
  animation: kcLineGlow 2.8s ease-in-out infinite;
}
@keyframes kcLineGlow{
  0%,100%{opacity:.78}
  50%{opacity:1}
}

/* nodes */
.kc-node{
  position:absolute;
  left: var(--x);
  top:  var(--y);
  transform: translate(-50%, -50%);
  background: transparent;
  border: 0;
  padding: 0;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.kc-node:focus-visible{
  outline: 3px solid rgba(17,141,201,.35);
  outline-offset: 6px;
  border-radius: 18px;
}

.kc-node__dot{
  width: 12px; height:12px; border-radius:999px;
  background: rgba(17,141,201,.95);
  box-shadow: 0 0 0 0 rgba(17,141,201,.25);
  animation: kcPulse 2.1s ease-in-out infinite;
}
@keyframes kcPulse{
  0%{box-shadow: 0 0 0 0 rgba(17,141,201,.25)}
  70%{box-shadow: 0 0 0 14px rgba(17,141,201,0)}
  100%{box-shadow: 0 0 0 0 rgba(17,141,201,0)}
}

.kc-node__label{
  font-size: 12px;
  font-weight: 800;
  color: rgba(15,23,42,.86);
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 999px;
  padding: 6px 10px;
  box-shadow: 0 10px 26px rgba(15,23,42,.06);
  white-space: nowrap;
}

.kc-node.is-active .kc-node__dot{
  background: rgba(249,178,22,.95);
  animation: kcPulseOrange 2.1s ease-in-out infinite;
}
@keyframes kcPulseOrange{
  0%{box-shadow: 0 0 0 0 rgba(249,178,22,.22)}
  70%{box-shadow: 0 0 0 14px rgba(249,178,22,0)}
  100%{box-shadow: 0 0 0 0 rgba(249,178,22,0)}
}

/* center node */
.kc-node--center{cursor:default}
.kc-node__core{
  width: 110px; height:110px;
  border-radius: 30px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 18px 44px rgba(15,23,42,.10);
  display:grid;
  place-items:center;
  overflow:hidden;
}
.kc-node--center .custom-logo-link{
  display:flex;
  align-items:center;
  justify-content:center;
}
.kc-node--center img.custom-logo{
  max-width: 92px;
  max-height: 92px;
  width:auto;
  height:auto;
}

/* ring halus */
.kc-node__ring{
  position:absolute;
  width: 160px; height:160px;
  border-radius:999px;
  border: 1px solid rgba(17,141,201,.18);
  box-shadow: 0 0 0 0 rgba(17,141,201,.10);
  animation: kcRing 3.2s ease-in-out infinite;
  pointer-events:none;
}
@keyframes kcRing{
  0%,100%{transform: translate(-50%, -50%) scale(1); opacity:.8}
  50%{transform: translate(-50%, -50%) scale(1.06); opacity:1}
}

/* panel detail (desktop overlay) */
.kc-constellation__panel{
  position:absolute;
  left: 18px;
  bottom: 18px;
  width: min(520px, calc(100% - 36px));
  padding: 16px 16px 14px;
  border-radius: 18px;
  background: rgba(10, 16, 30, .78);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 22px 60px rgba(0,0,0,.32);
  color:#fff;
}
.kc-constellation__kicker{
  margin:0 0 6px;
  font-size:.85rem;
  font-weight:800;
  color: rgba(255,255,255,.70);
}
.kc-constellation__title{
  margin:0 0 8px;
  font-size: 1.15rem;
  font-weight: 900;
  color: rgba(255,255,255,.98);
}
.kc-constellation__desc{
  margin:0 0 12px;
  color: rgba(255,255,255,.90);
}

/* hide mobile fallback on desktop */
.kc-constellation-mobile{display:none;}

/* -------------------------
   CONSTELLATION (MOBILE)
------------------------- */
@media (max-width:860px){
  .kc-constellation{display:none;}
  .kc-constellation-mobile{display:block;}
  .kc-constellation-mobile__head{margin-bottom:12px}
  .kc-constellation-mobile__list{
    display:grid;
    gap:10px;
  }
  .kc-svcmini{
    display:grid;
    gap:4px;
    padding:14px 14px;
    border-radius: 16px;
    background:#fff;
    border:1px solid var(--kc-line);
    box-shadow: var(--kc-shadow-sm);
  }
  .kc-svcmini__dot{
    width:10px; height:10px; border-radius:999px;
    background: rgba(17,141,201,.95);
  }
  .kc-svcmini__title{font-weight:900}
  .kc-svcmini__desc{color:var(--kc-slate-700)}
}

/* -------------------------
   WORKFLOW STEPS
------------------------- */
.kc-steps2{
  display:grid;
  gap:12px;
}
@media (min-width:768px){
  .kc-steps2{grid-template-columns: repeat(2, minmax(0,1fr));}
}
@media (min-width:1024px){
  .kc-steps2{grid-template-columns: repeat(4, minmax(0,1fr));}
}

.kc-step2{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 14px 34px rgba(15,23,42,.06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-step2:hover{
  transform: translateY(-3px);
  border-color: rgba(17,141,201,.16);
  box-shadow: 0 22px 55px rgba(15,23,42,.10);
}
.kc-step2__ico{
  width:36px; height:36px; border-radius:14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(17,141,201,.18), rgba(249,178,22,.14));
  border: 1px solid rgba(15,23,42,.08);
  margin-bottom: 10px;
}
.kc-step2 p{margin:0; color: var(--kc-slate-700)}

/* -------------------------
   PRINCIPLES + PROOF
------------------------- */
.kc-about-principles{
  background:
    radial-gradient(900px 420px at 18% 10%, rgba(17,141,201,.10), rgba(255,255,255,0)),
    radial-gradient(700px 320px at 85% 18%, rgba(249,178,22,.12), rgba(255,255,255,0)),
    linear-gradient(180deg, rgba(245,249,255,.92), rgba(255,255,255,.88));
}
.kc-about-principles__grid{
  display:grid;
  gap:16px;
}
@media (min-width:980px){
  .kc-about-principles__grid{
    grid-template-columns: 1fr 1fr;
    align-items:start;
    gap:18px;
  }
}

/* chips */
.kc-chips{
  list-style:none;
  padding:0;
  margin: 14px 0 0;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.kc-chips li{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 12px 26px rgba(15,23,42,.06);
}
.kc-chips li:before{
  content:"";
  width:10px; height:10px; border-radius:999px;
  background: rgba(17,141,201,.95);
}
.kc-chips li strong{font-weight:900;}
.kc-chips li span{opacity:.82;}

/* proof tiles */
.kc-proof--tiles{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
@media (max-width:720px){
  .kc-proof--tiles{grid-template-columns: 1fr;}
}
.kc-proof__tile{
  display:block;
  border-radius: 18px;
  padding: 16px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 14px 34px rgba(15,23,42,.06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-proof__tile:hover{
  transform: translateY(-3px);
  border-color: rgba(17,141,201,.18);
  box-shadow: 0 22px 55px rgba(15,23,42,.10);
}
.kc-proof__ico{
  width:38px; height:38px; border-radius:14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(17,141,201,.18), rgba(249,178,22,.14));
  border: 1px solid rgba(15,23,42,.08);
  margin-bottom: 10px;
}
.kc-proof__title{margin:0; font-weight:900; font-size:18px;}
.kc-proof__desc{margin:6px 0 10px; opacity:.88; color:var(--kc-slate-700);}
.kc-proof__meta{margin:0; font-size:13px; opacity:.72; color:var(--kc-slate-500);}

/* -------------------------
   CTA PANEL
------------------------- */
.kc-panel{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 18px;
  box-shadow: var(--kc-shadow-sm);
}
.kc-panel--soft{
  background:
    radial-gradient(600px 240px at 15% 30%, rgba(17,141,201,.10), rgba(255,255,255,0)),
    radial-gradient(500px 220px at 85% 30%, rgba(249,178,22,.10), rgba(255,255,255,0)),
    #fff;
}
.kc-panel__copy p{margin:6px 0 0; color: var(--kc-slate-700)}
.kc-panel__actions{margin-top:14px}

/* -------------------------
   REVEAL
------------------------- */
.kc-reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .55s ease, transform .55s ease;
}
.kc-reveal.is-in{
  opacity: 1;
  transform: translateY(0);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .kc-line, .kc-node__dot, .kc-node__ring{animation:none !important}
  .kc-reveal{transition:none !important}
}
/* =========================
   ABOUT FIX PACK v2.3
   (panel behavior + mobile swipe/grid + typography)
========================= */

/* A) Constellation panel: jangan nutup node.
   - Pindah ke kanan bawah
   - Default hidden (akan di-open oleh JS saat user interaksi)
*/
.kc-constellation{
  /* kasih ruang aman biar panel gak â€œketabrakâ€ elemen lain */
  padding-bottom: 120px;
}

.kc-constellation__panel{
  left: auto !important;
  right: 18px;
  bottom: 18px;

  max-width: 380px;
  width: min(380px, calc(100% - 36px));

  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.kc-constellation.is-panel-open .kc-constellation__panel{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* B) Constellation mobile: ubah jadi swipe horizontal (scroll snap) */
@media (max-width: 860px){
  .kc-constellation-mobile__list{
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 86%;
    gap: 12px;

    overflow-x: auto;
    padding-bottom: 8px;

    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .kc-constellation-mobile__list > a{
    scroll-snap-align: start;
  }
}

/* C) Steps: 2 grid di mobile (biar gak kepanjangan) */
@media (max-width: 720px){
  .kc-steps2{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px;
  }
  .kc-step2{
    padding: 14px;
  }
  .kc-step2 .kc-h3{
    font-size: 14px;
    line-height: 1.2;
    margin-bottom: 6px;
  }
  .kc-step2 p{
    font-size: 12.5px;
    line-height: 1.35;
  }
}

/* D) Chips: swipe horizontal di mobile */
@media (max-width: 720px){
  .kc-chips{
    flex-wrap: nowrap !important;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
  }
  .kc-chips li{
    scroll-snap-align: start;
    white-space: nowrap;
    padding: 9px 10px;
    gap: 8px;
  }
  .kc-chips li strong{ font-size: 12.5px; }
  .kc-chips li span{ font-size: 12px; }
}

/* E) Proof tiles: 2 grid di mobile + rapikan font & spacing */
@media (max-width: 720px){
  .kc-proof--tiles{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px;
  }
  .kc-proof__tile{
    padding: 12px;
    border-radius: 16px;
  }
  .kc-proof__ico{
    width: 34px;
    height: 34px;
    border-radius: 13px;
    margin-bottom: 8px;
  }
  .kc-proof__title{
    font-size: 14px;
    line-height: 1.2;
  }
  .kc-proof__desc{
    font-size: 12px;
    line-height: 1.35;
    margin: 6px 0 8px;
  }
  .kc-proof__meta{
    font-size: 11px;
    line-height: 1.2;
  }
}

/* F) Very small screens: biar tetap kebaca */
@media (max-width: 380px){
  .kc-proof--tiles{
    grid-template-columns: 1fr !important; /* fallback kalau terlalu sempit */
  }
}
/* =========================
   FIX: PROOF TILES MOBILE
========================= */

@media (max-width: 720px){
  .kc-proof.kc-proof--tiles{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    width: 100%;
  }

  /* penting untuk cegah overflow grid item */
  .kc-proof.kc-proof--tiles > .kc-proof__tile{
    min-width: 0;
    width: 100%;
  }

  /* rapikan typografi biar padat */
  .kc-proof__title{
    font-size: 14px;
    line-height: 1.2;
  }
  .kc-proof__desc{
    font-size: 12px;
    line-height: 1.35;
    margin: 6px 0 8px;

    /* optional: biar tidak kepanjangan (clamp) */
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .kc-proof__meta{
    font-size: 11px;
    line-height: 1.2;
  }
}

/* kalau layar super sempit, fallback jadi 1 kolom */
@media (max-width: 380px){
  .kc-proof.kc-proof--tiles{
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 720px){
  .kc-proof__tile{
    padding: 12px;
    border-radius: 16px;
  }
  .kc-proof__ico{
    width: 34px;
    height: 34px;
    border-radius: 13px;
    margin-bottom: 8px;
  }
}
/* =========================
   FIX: CHIPS SWIPE TAPI TIDAK NGESER PAGE
========================= */

/* 1) PENTING: biar grid item boleh â€œmengecilâ€ dan tidak mendorong layout */
.kc-about-principles__grid > *{
  min-width: 0;
}

/* 2) Chips: scroll hanya di dalam area chips */
@media (max-width: 720px){
  .kc-chips{
    max-width: 100%;
    min-width: 0;
    flex-wrap: nowrap !important;

    overflow-x: auto;
    overflow-y: hidden;

    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;

    /* biar swipe chips gak â€œnarikâ€ page */
    overscroll-behavior-x: contain;
    touch-action: pan-x;

    padding-bottom: 6px;
  }

  .kc-chips li{
    flex: 0 0 auto; /* jangan biar flex nge-stretch/nyebar aneh */
    white-space: nowrap;
    scroll-snap-align: start;
  }
}

/* 3) Safety net: kalau ada 1 elemen masih bikin overflow */
html, body{
  overflow-x: hidden;
}

/* =========================
   ABOUT PAGE – Neural Network / Connecting the Dots
   Paste di AKHIR components.css (GANTI yang solar system)
   ========================= */

/* Section background */
.kc-about-constellation{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(900px 420px at 20% 20%, rgba(17,141,201,.10), rgba(255,255,255,0)),
    radial-gradient(800px 380px at 80% 30%, rgba(249,178,22,.12), rgba(255,255,255,0)),
    linear-gradient(180deg, rgba(255,255,255,.90), rgba(245,247,251,.86));
}

/* Desktop only */
@media (min-width: 860px){
  .kc-neural-net{
    position: relative;
    width: 100%;
    min-height: 520px;
    display: grid;
    place-items: center;
    background: transparent;
    overflow: visible;
  }

  /* SVG container for connecting lines */
  .kc-neural-net__svg{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
  }

  /* SVG paths (lines) */
  .kc-neural-line{
    fill: none;
    stroke: rgba(148,163,184,.28);
    stroke-width: 1.5;
    stroke-linecap: round;
    transition: stroke .22s ease, stroke-width .22s ease, opacity .22s ease;
    filter: drop-shadow(0 0 4px rgba(148,163,184,.15));
  }

  /* Active line (when dot hovered) */
  .kc-neural-line.is-active{
    stroke: rgba(17,141,201,.75);
    stroke-width: 2.5;
    filter: drop-shadow(0 0 8px rgba(17,141,201,.35));
    
    /* Animated dash flow */
    stroke-dasharray: 8 6;
    animation: neuralFlow 1.8s linear infinite;
  }

  @keyframes neuralFlow{
    to { stroke-dashoffset: -28; }
  }

  /* Hub (center logo) */
  .kc-neural-hub{
    position: relative;
    z-index: 10;
    width: 110px;
    height: 110px;
    border-radius: 100%;
    border: 1px solid rgba(148,163,184,.30);
    background: 
      radial-gradient(circle at 35% 35%, rgba(255,255,255,.98), rgba(245,247,251,.90)),
      #fff;
    box-shadow: 
      0 0 0 8px rgba(17,141,201,.06),
      0 18px 44px rgba(15,23,42,.12);
    display: grid;
    place-items: center;
    overflow: hidden;
  }

  .kc-neural-hub .custom-logo-link{
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .kc-neural-hub img.custom-logo{
    max-width: 92px;
    max-height: 92px;
    width: auto;
    height: auto;
    object-fit: contain;
  }

  .kc-neural-hub__mark{
    font-weight: 900;
    font-size: 24px;
    letter-spacing: -.02em;
    color: rgba(11,18,32,.88);
  }

  /* Neural Dot (service node) */
  .kc-neural-dot{
    position: absolute;
    left: var(--x);
    top: var(--y);
    transform: translate(-50%, -50%);
    border: 0;
    background: transparent;
    padding: 0;
    cursor: pointer;
    z-index: 5;
    
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    
    /* Subtle floating */
    animation: neuralFloat var(--float-duration, 3.5s) ease-in-out infinite;
    animation-delay: var(--float-delay, 0s);
  }

  @keyframes neuralFloat{
    0%, 100% { transform: translate(-50%, -50%) translateY(0); }
    50% { transform: translate(-50%, -50%) translateY(-5px); }
  }

  .kc-neural-dot__node{
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: 
      radial-gradient(circle at 30% 30%, rgba(255,255,255,.95), rgba(17,141,201,.22) 55%, rgba(249,178,22,.18)),
      #fff;
    box-shadow: 
      0 0 0 0 rgba(17,141,201,.15),
      0 14px 36px rgba(15, 23, 42, .10);
    border: 1px solid rgba(148,163,184,.35);
    transition: transform .18s ease, box-shadow .22s ease, border-color .18s ease;
    
    /* Subtle pulse */
    animation: neuralPulse 2.5s ease-in-out infinite;
  }

  @keyframes neuralPulse{
    0%, 100% { 
      box-shadow: 
        0 0 0 0 rgba(17,141,201,.15),
        0 14px 36px rgba(15, 23, 42, .10);
    }
    50% { 
      box-shadow: 
        0 0 0 6px rgba(17,141,201,.08),
        0 14px 36px rgba(15, 23, 42, .10);
    }
  }

  .kc-neural-dot__label{
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .01em;
    color: rgba(11,18,32,.80);
    background: rgba(255,255,255,.90);
    border: 1px solid rgba(148,163,184,.22);
    border-radius: 999px;
    padding: 5px 10px;
    box-shadow: 0 8px 18px rgba(15,23,42,.06);
    white-space: nowrap;
    transition: all .18s ease;
  }

  /* Hover state */
  .kc-neural-dot:hover .kc-neural-dot__node,
  .kc-neural-dot:focus-visible .kc-neural-dot__node{
    transform: scale(1.35);
    box-shadow: 
      0 0 0 10px rgba(17,141,201,.12),
      0 18px 48px rgba(15, 23, 42, .16);
    border-color: rgba(17,141,201,.55);
  }

  .kc-neural-dot:hover .kc-neural-dot__label,
  .kc-neural-dot:focus-visible .kc-neural-dot__label{
    border-color: rgba(17,141,201,.35);
    background: rgba(255,255,255,.98);
    box-shadow: 0 12px 28px rgba(15,23,42,.10);
  }

  /* Pause float animation on hover */
  .kc-neural-dot:hover,
  .kc-neural-dot:focus-visible{
    animation-play-state: paused;
  }

  .kc-neural-dot:focus-visible{
    outline: 3px solid rgba(17,141,201,.35);
    outline-offset: 8px;
    border-radius: 16px;
  }

  /* Tooltip */
  .kc-neural-tooltip{
    position: absolute;
    z-index: 20;
    pointer-events: auto;
    
    min-width: 200px;
    max-width: 280px;
    padding: 12px 12px;
    
    border-radius: 16px;
    border: 1px solid rgba(148,163,184,.35);
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(14px);
    box-shadow: 
      0 0 0 1px rgba(17,141,201,.08),
      0 22px 70px rgba(15,23,42,.14);
    
    opacity: 0;
    transform: translateY(4px);
    transition: opacity .18s ease, transform .18s ease;
  }

  .kc-neural-tooltip:not([hidden]){
    opacity: 1;
    transform: translateY(0);
  }

  .kc-neural-tooltip__title{
    display: block;
    font-weight: 900;
    font-size: 14px;
    margin-bottom: 6px;
    color: rgba(11,18,32,.92);
  }

  .kc-neural-tooltip__desc{
    margin: 0 0 10px;
    font-size: 13px;
    line-height: 1.45;
    color: var(--kc-slate-700);
  }

  /* Reduced motion */
  @media (prefers-reduced-motion: reduce){
    .kc-neural-dot{ animation: none !important; }
    .kc-neural-dot__node{ animation: none !important; }
    .kc-neural-line.is-active{ animation: none !important; }
  }
}

/* Mobile: hide neural net, show list */
@media (max-width: 859px){
  .kc-neural-net{ display: none; }
}
/* Back to top */
.kc-totop{
  position:fixed;
  right:16px;
  bottom:16px;
  bottom:calc(16px + env(safe-area-inset-bottom, 0px));
  z-index:60;

  width:52px;
  height:52px;
  border-radius:999px;
  border:1px solid var(--kc-line);
  background:radial-gradient(1200px 600px at 18% 10%, rgba(17, 141, 201, 0.4), transparent 10%),
    radial-gradient(900px 520px at 12% 26%, rgba(249,178,22,.1), transparent 10%),
    linear-gradient(90deg, rgba(245,247,251,.65), rgba(255,255,255,0));
  color:var(--kc-ink);
  box-shadow:var(--kc-shadow-md);

  display:grid;
  place-items:center;
  cursor:pointer;

  opacity:0;
  transform:translateY(10px) scale(.98);
  transition:opacity .2s ease, transform .2s ease;
  pointer-events:none;
  -webkit-tap-highlight-color: transparent;
}

.kc-totop.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}

.kc-totop:hover{
  transform:translateY(-2px) scale(1);
}

.kc-totop:active{
  transform:translateY(0) scale(.99);
}

.kc-totop__ring{
  position:absolute;
  inset:-6px;
  display:grid;
  place-items:center;
  pointer-events:none;
}

.kc-totop__svg{
  width:64px;
  height:64px;
}

.kc-totop__track{
  fill:none;
  stroke:rgba(100,116,139,.25);
  stroke-width:3;
}

.kc-totop__progress{
  fill:none;
  stroke:var(--kc-orange-500);
  stroke-width:3;
  stroke-linecap:round;
  transform:rotate(-90deg);
  transform-origin:50% 50%;
  stroke-dasharray: 113.1; /* set via JS too, tapi ini default aman */
  stroke-dashoffset: 113.1;
}

@media (prefers-reduced-motion: reduce){
  .kc-totop{transition:none}
  .kc-totop:hover{transform:none}
}
/* =========================================
   Contact page — Quick Contact panel (scoped)
   Aman: tidak bentrok dengan home form
   ========================================= */

/* penting: supaya panel tidak ikut stretch setinggi form (biar nggak ada area kosong) */
.kc-grid--contact{
  align-items: start;
}

.kc-panel--contact{
  align-self: start;
  padding: 18px;
  background:
    radial-gradient(520px 240px at 10% 10%, rgba(17,141,201,.10), transparent 60%),
    radial-gradient(520px 240px at 90% 35%, rgba(249,178,22,.14), transparent 62%),
    #fff;
}

.kc-panel--contact .kc-h3{ margin: 0 0 6px; }
.kc-panel--contact .kc-lead{
  font-size: .95rem;
  margin: 0 0 14px;
  color: var(--kc-slate-700);
}

.kc-quick{
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.kc-quick__item{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid var(--kc-line);
  background: rgba(255,255,255,.92);
  text-decoration: none;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease, background .12s ease;
}
.kc-quick__item:hover{
  transform: translateY(-1px);
  border-color: rgba(17,141,201,.35);
  box-shadow: var(--kc-shadow-sm);
  background: #fff;
}

.kc-quick__icon{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  color: rgba(11,18,32,.78);
  background: rgba(17,141,201,.10);
  border: 1px solid rgba(17,141,201,.18);
}

.kc-quick__item--wa .kc-quick__icon{
  background: rgba(20,199,100,.10);
  border-color: rgba(20,199,100,.22);
}
.kc-quick__item--email .kc-quick__icon{
  background: rgba(249,178,22,.14);
  border-color: rgba(249,178,22,.28);
}
.kc-quick__item--tel .kc-quick__icon{
  background: rgba(17,141,201,.10);
  border-color: rgba(17,141,201,.22);
}

.kc-quick__icon svg{ width: 18px; height: 18px; }

.kc-quick__text{
  min-width: 0;
  display: grid;
}
.kc-quick__title{
  font-weight: 850;
  color: rgba(11,18,32,.92);
  line-height: 1.1;
}
.kc-quick__meta{
  font-size: .86rem;
  color: var(--kc-slate-600);
  margin-top: 2px;
  line-height: 1.2;
}

.kc-quick__chev{
  margin-left: auto;
  color: var(--kc-slate-500);
  display: inline-flex;
}
.kc-quick__chev svg{ width: 16px; height: 16px; }

.kc-panel--contact .kc-meta{ margin: 12px 0 0; }

@media (max-width: 767px){
  .kc-panel--contact{ padding: 16px; }
  .kc-quick__item{ padding: 12px; }
}
/* =========================================
   Sticky Quick Contact (desktop only)
   ========================================= */
@media (min-width: 992px){
  .kc-panel--contact{
    position: sticky;
    top: 96px; /* aman untuk header fixed; bisa kamu kecilin kalau header lebih pendek */
    max-height: calc(100vh - 120px);
    overflow: auto;
  }

  /* scrollbar halus (opsional, aman) */
  .kc-panel--contact{
    scrollbar-width: thin;
    scrollbar-color: rgba(11,18,32,.25) transparent;
  }
  .kc-panel--contact::-webkit-scrollbar{ width: 10px; }
  .kc-panel--contact::-webkit-scrollbar-track{ background: transparent; }
  .kc-panel--contact::-webkit-scrollbar-thumb{
    background: rgba(11,18,32,.18);
    border-radius: 999px;
    border: 3px solid transparent;
    background-clip: content-box;
  }
  .kc-panel--contact::-webkit-scrollbar-thumb:hover{
    background: rgba(11,18,32,.26);
    border: 3px solid transparent;
    background-clip: content-box;
  }
}

/* Matikan sticky untuk mobile/tablet kecil biar nggak “ngeganggu” */
@media (max-width: 991px){
  .kc-panel--contact{
    position: static;
    max-height: none;
    overflow: visible;
  }
}
/* =========================================================
   SERVICES HUB — /layanan-kami/
   Scoped: .kc-section--serviceshub, .kc-card--svcHub, etc.
   ========================================================= */

.kc-section--serviceshub{ position: relative; overflow: visible; }

.kc-servicesHero__chips{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

.kc-servicesRail{
  padding: 18px;
  background:
    radial-gradient(520px 240px at 10% 10%, rgba(17,141,201,.10), transparent 60%),
    radial-gradient(520px 240px at 90% 35%, rgba(249,178,22,.14), transparent 62%),
    #fff;
}

.kc-servicesRail__top .kc-h3{ margin: 0 0 6px; }
.kc-servicesRail__top .kc-meta{ margin: 0 0 12px; }

.kc-path{
  display:grid;
  gap:10px;
  margin: 10px 0 14px;
}

.kc-path__card{
  display:grid;
  gap:2px;
  padding:12px 12px;
  border-radius: 16px;
  border:1px solid var(--kc-line);
  background: rgba(255,255,255,.92);
  text-decoration:none;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.kc-path__card:hover{
  transform: translateY(-1px);
  border-color: rgba(17,141,201,.30);
  box-shadow: 0 18px 55px rgba(15, 23, 42, .10);
}
.kc-path__k{ font-weight: 900; color: rgba(11,18,32,.92); line-height:1.1; }
.kc-path__v{ font-size: .88rem; color: var(--kc-slate-600); }

.kc-servicesRail__mini{
  border-top:1px solid rgba(226,232,240,.8);
  padding-top:12px;
  display:grid;
  gap:8px;
}
.kc-mini__row{ display:flex; align-items:center; gap:10px; }
.kc-mini__dot{
  width:8px; height:8px; border-radius:999px;
  background: rgba(17,141,201,.45);
  box-shadow: 0 10px 20px rgba(17,141,201,.18);
}
.kc-mini__txt{ font-size:.9rem; color: var(--kc-slate-700); }

/* Services grid enhancements */
.kc-servicesGrid{ margin-top: 16px; }

.kc-card--svcHub{
  padding: 18px 16px;
  position: relative;
  overflow: hidden;
}
.kc-card--svcHub::before{
  content:"";
  position:absolute; inset:-1px;
  background:
    radial-gradient(520px 220px at 10% 10%, rgba(17,141,201,.10), transparent 62%),
    radial-gradient(520px 220px at 90% 40%, rgba(249,178,22,.12), transparent 64%);
  opacity: .0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.kc-card--svcHub:hover::before{ opacity: 1; }

.kc-card--svcHub .kc-card__top{ margin-bottom: 10px; }
.kc-card--svcHub .kc-card__title{ margin: 0; }
.kc-card--svcHub .kc-card__head{ display:grid; gap:2px; min-width:0; }

.kc-svcTag{
  margin:0;
  font-size:.82rem;
  color: var(--kc-slate-500);
}

.kc-card--svcHub .kc-card__desc{
  margin: 0;
  line-height: 1.5;
}

.kc-svcList{
  list-style:none;
  padding:0;
  margin: 12px 0 0;
  display:grid;
  gap:8px;
  color: var(--kc-slate-700);
}
.kc-svcList li{
  position:relative;
  padding-left:18px;
  line-height:1.35;
}
.kc-svcList li::before{
  content:"";
  position:absolute;
  left:0; top:.45em;
  width:10px; height:10px;
  border-radius: 4px;
  background: rgba(249,178,22,.30);
  border: 1px solid rgba(249,178,22,.45);
}

.kc-svcActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top: 14px;
}

/* Workflow small polish */
.kc-steps--serviceshub .kc-step--svc{
  background:
    radial-gradient(520px 220px at 10% 10%, rgba(17,141,201,.08), transparent 62%),
    #fff;
}
.kc-steps--serviceshub .kc-step--svc h3{ font-weight: 900; }

/* FAQ details support */
.kc-acc--details > summary{ list-style: none; }
.kc-acc--details > summary::-webkit-details-marker{ display:none; }

.kc-acc--details[open] .kc-acc__icon::before{
  transform: rotate(-135deg);
}

.kc-acc--details[open]{
  border-color: rgba(17,141,201,.22);
}
.kc-acc--details[open] .kc-acc__icon{
  transform: translateY(-1px);
  border-color: rgba(17,141,201,.34);
}

/* Bottom CTA */
.kc-cta--serviceshub{
  margin-top: 18px;
  background:
    radial-gradient(720px 260px at 12% 12%, rgba(17,141,201,.14), transparent 60%),
    radial-gradient(720px 260px at 88% 42%, rgba(249,178,22,.18), transparent 62%),
    linear-gradient(135deg, rgba(215,240,255,.75), #fff);
}

/* Sticky rail on desktop (nyambung sama fix header kamu) */
@media (min-width: 992px){
  .kc-servicesRail{
    position: sticky;
    top: 96px;
    max-height: calc(100vh - 120px);
    overflow: auto;
  }
}

/* Mobile: rapikan spacing */
@media (max-width: 767px){
  .kc-card--svcHub{ padding: 16px 14px; }
  .kc-svcActions .kc-btn{ width: 100%; justify-content: center; }
}
/* =========================================================
   SERVICES HUB — Mobile polishing
   - Chips swipe
   - Steps 2-column
   - Button row 2-column
   Scoped: .kc-section--serviceshub + .kc-cta--serviceshub
   ========================================================= */

/* 1) Chips swipe on mobile */
@media (max-width: 767px){
  .kc-section--serviceshub .kc-servicesHero__chips{
    position: relative;
    flex-wrap: nowrap;                 /* stop wrapping */
    overflow-x: auto;                  /* enable horizontal swipe */
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch; /* smooth iOS scroll */
    overscroll-behavior-x: contain;    /* prevent body side-swipe */
    gap: 10px;
    padding: 6px 2px 8px;
    margin-top: 12px;
    scroll-snap-type: x proximity;     /* snap “soft” */
    scrollbar-width: none;             /* Firefox hide scrollbar */
  }
  .kc-section--serviceshub .kc-servicesHero__chips::-webkit-scrollbar{
    display: none;                     /* Chrome/Safari hide scrollbar */
  }

  .kc-section--serviceshub .kc-servicesHero__chips .kc-badge{
    flex: 0 0 auto;
    white-space: nowrap;
    scroll-snap-align: start;
  }

  /* optional: edge fade (biar keliatan bisa digeser) */
  .kc-section--serviceshub .kc-servicesHero__chips::before,
  .kc-section--serviceshub .kc-servicesHero__chips::after{
    content:"";
    position:absolute;
    top:0; bottom:0;
    width: 18px;
    pointer-events:none;
  }
}

/* 2) Steps jadi 2 kolom (2x2) di mobile */
@media (max-width: 767px){
  .kc-steps--serviceshub{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .kc-steps--serviceshub .kc-step--svc{
    padding: 12px 12px;
    border-radius: 16px;
  }

  .kc-steps--serviceshub .kc-step--svc h3{
    font-size: .95rem;
    line-height: 1.15;
    margin-bottom: 6px;
  }

  .kc-steps--serviceshub .kc-step--svc p{
    font-size: .86rem;
    line-height: 1.35;
    margin: 0;
  }
}

/* 3) Btnrow jadi 2 grid di mobile (hero + bottom CTA) */
@media (max-width: 767px){
  /* hero btnrow */
  .kc-section--serviceshub .kc-btnrow{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px; /* biar rapih setelah chips */
  }
  .kc-section--serviceshub .kc-btnrow .kc-btn{
    width: 100%;
    justify-content: center;
    padding: 12px 12px;     /* sedikit lebih compact */
    font-size: .95rem;
  }

  /* bottom CTA btnrow */
  .kc-cta--serviceshub .kc-btnrow{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .kc-cta--serviceshub .kc-btnrow .kc-btn{
    width: 100%;
    justify-content: center;
    padding: 12px 12px;
    font-size: .92rem;
  }
}

/* ekstra: kalau layar super kecil (<= 360px), biar nggak sempit banget */
@media (max-width: 360px){
  .kc-section--serviceshub .kc-btnrow,
  .kc-cta--serviceshub .kc-btnrow{
    grid-template-columns: 1fr;
  }
}
/* =========================================================
   SERVICES HUB — Breadcrumb separator visibility
   ========================================================= */
.kc-section--serviceshub .kc-breadcrumbs__item:not(:last-child)::after{
  content: "/";                        /* pastiin ada slash */
  color: rgba(11,18,32,.32);           /* lebih kebaca di hero gradient */
  margin: 0 10px;                      /* spasi kiri-kanan biar rapi */
}
.kc-section--serviceshub .kc-breadcrumbs__list{
  gap: 0; /* biar spasi diatur oleh margin separator di atas */
}
/* =========================
   Digital Marketing Page
========================= */
.kc-page--digital-marketing .kc-breadcrumbs{
  display:flex; flex-wrap:wrap; gap:10px;
  font-size:14px; opacity:.85;
  padding-top:14px; padding-bottom:8px;
}
.kc-breadcrumbs__sep{ opacity:.55; }

.kc-hero--dm{
  position:relative;
  padding:56px 0 28px;
  color:#fff;
  background:
    radial-gradient(1200px 600px at 15% 10%, rgba(255,140,0,.35), transparent 55%),
    radial-gradient(900px 520px at 85% 0%, rgba(0,170,255,.18), transparent 60%),
    linear-gradient(180deg, #0a0c10 0%, #0b0d12 100%);
  overflow:hidden;
}
.kc-hero--dm::after{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(700px 220px at 30% 20%, rgba(255,255,255,.08), transparent 60%),
    radial-gradient(520px 220px at 70% 55%, rgba(255,255,255,.06), transparent 60%);
  pointer-events:none;
}
.kc-hero__grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:24px;
  position:relative;
  z-index:1;
}
@media (max-width: 980px){
  .kc-hero__grid{ grid-template-columns:1fr; }
}

.kc-chips--dm{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:18px 0 18px;
}
.kc-chip{
  display:inline-flex;
  align-items:center;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  color:#fff;
  text-decoration:none;
  font-size:13px;
  line-height:1;
  backdrop-filter: blur(8px);
}
.kc-chip:hover{ background:rgba(255,255,255,.10); border-color:rgba(255,255,255,.22); }

.kc-swipe{
  position:relative;
}
@media (max-width: 640px){
  .kc-chips--dm{
    flex-wrap:nowrap;
    overflow:auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom:6px;
  }
  .kc-chips--dm .kc-chip{
    flex:0 0 auto;
    scroll-snap-align: start;
    white-space:nowrap;
  }
  .kc-chips--dm::-webkit-scrollbar{ display:none; }
}

/* Swipe hint dot */
.kc-swipehint{
  position:absolute;
  right:10px;
  bottom:-2px;
  width:7px;
  height:7px;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  box-shadow:0 0 0 6px rgba(255,255,255,.14);
  animation: kcSwipeHint 2.2s ease both;
  pointer-events:none;
}
@keyframes kcSwipeHint{
  0%{ opacity:0; transform:translateX(0); }
  12%{ opacity:1; }
  55%{ opacity:1; transform:translateX(-16px); }
  100%{ opacity:0; transform:translateX(-22px); }
}

.kc-btnrow--dm{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  margin-top:10px;
}
@media (max-width: 560px){
  .kc-btnrow--dm{ grid-template-columns:1fr 1fr; }
  .kc-btnrow--dm .kc-btn{ padding:12px 12px; font-size:14px; }
}

.kc-dmHero__bullets{
  margin:18px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.kc-dmHero__bullets li{
  display:flex; gap:10px;
  color:rgba(255,255,255,.88);
}
.kc-dot{
  width:8px; height:8px;
  border-radius:999px;
  margin-top:8px;
  background:rgba(255,140,0,.95);
  box-shadow:0 0 0 6px rgba(255,140,0,.12);
}

.kc-panel--dm{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  padding:18px;
  backdrop-filter: blur(10px);
}
.kc-panel--dm .kc-muted{ color:rgba(255,255,255,.75); }

.kc-metricgrid{
  margin-top:14px;
  display:grid;
  gap:12px;
}
.kc-metric{
  display:flex;
  gap:12px;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.22);
}
.kc-metric--wide{ padding:14px; }
.kc-metric__icon{
  width:34px; height:34px;
  border-radius:12px;
  display:grid; place-items:center;
  background:rgba(255,140,0,.14);
  border:1px solid rgba(255,140,0,.22);
  color:#fff;
}
.kc-metric__icon svg{ width:18px; height:18px; }
.kc-metric__label{ font-size:12px; opacity:.8; }
.kc-metric__value{ font-size:14px; font-weight:600; }

.kc-quote{ position:relative; }
.kc-quote__mark{
  font-size:34px;
  line-height:1;
  opacity:.7;
  color:rgba(255,140,0,.95);
}
.kc-quote__text{
  margin:6px 0 8px;
  font-weight:600;
}
.kc-quote__by{
  margin:0;
  font-size:12px;
  opacity:.75;
}

.kc-grid--dmServices{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
}
.kc-card--dm{
  grid-column: span 6;
  border-radius:18px;
  border:1px solid rgba(10,12,16,.10);
  background:#fff;
  padding:18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
}
.kc-card--dmWide{ grid-column: span 12; }
.kc-card--dm .kc-muted{ opacity:.75; }
.kc-list{ margin:12px 0 0; padding-left:18px; }
.kc-pillrow{ display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; }
.kc-pill{
  display:inline-flex;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(10,12,16,.10);
  background:rgba(255,140,0,.08);
  font-size:12px;
}

@media (max-width: 860px){
  .kc-card--dm{ grid-column: span 12; }
}

.kc-grid--dmProof{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}
.kc-proofCard{
  border-radius:18px;
  border:1px solid rgba(10,12,16,.10);
  background:linear-gradient(180deg, #fff 0%, #fff7ef 100%);
  padding:18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
}
.kc-proofCard__kpi{
  font-size:22px;
  font-weight:800;
  letter-spacing:-.02em;
}
.kc-proofCard__desc{ margin-top:8px; opacity:.82; }
.kc-proofCard__src{ margin-top:10px; font-size:12px; opacity:.65; }

@media (max-width: 860px){
  .kc-grid--dmProof{ grid-template-columns:1fr; }
}

.kc-steps--dm{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
.kc-step{
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(10,12,16,.10);
  padding:18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.05);
}
.kc-step__num{
  width:40px; height:40px;
  border-radius:14px;
  display:grid; place-items:center;
  font-weight:800;
  background:rgba(255,140,0,.12);
  border:1px solid rgba(255,140,0,.22);
  margin-bottom:12px;
}
@media (max-width: 860px){
  .kc-steps--dm{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px){
  .kc-steps--dm{ grid-template-columns: repeat(2, 1fr); }
  .kc-step{ padding:14px; }
  .kc-step .kc-muted{ font-size:13px; line-height:1.45; }
}

.kc-grid--dmDeliverables{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
@media (max-width: 980px){
  .kc-grid--dmDeliverables{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px){
  .kc-grid--dmDeliverables{ grid-template-columns: repeat(2, 1fr); }
  .kc-grid--dmDeliverables .kc-card--dm{ padding:14px; }
}

.kc-faq__item{
  border-radius:16px;
  border:1px solid rgba(10,12,16,.10);
  background:#fff;
  padding:14px 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,.04);
}
.kc-faq{ display:grid; gap:12px; }
.kc-faq__item summary{
  cursor:pointer;
  font-weight:700;
}
.kc-faq__content{
  padding-top:10px;
  opacity:.82;
}

.kc-section--cta{
  background:
    radial-gradient(900px 420px at 20% 20%, rgba(255,140,0,.18), transparent 60%),
    linear-gradient(180deg, #0a0c10 0%, #0b0d12 100%);
  color:#fff;
}
.kc-ctaGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  margin-top:16px;
}
.kc-ctaCard, .kc-ctaForm{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  padding:18px;
  backdrop-filter: blur(10px);
}
@media (max-width: 860px){
  .kc-ctaGrid{ grid-template-columns:1fr; }
}
/* =========================
   DIGITAL MARKETING PAGE
   ========================= */

/* HERO: contained (non-fullwidth) + readable on dark */
.kc-hero--dm{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(900px 520px at 20% 15%, rgba(255,153,51,.22), transparent 55%),
    radial-gradient(900px 520px at 78% 20%, rgba(0,153,255,.18), transparent 60%),
    linear-gradient(135deg, #0b0f14 0%, #06080c 100%);
}

/* breadcrumbs inside hero */
.kc-hero--dm .kc-hero__breadcrumbs{
  margin-bottom: 14px;
  opacity: .92;
}

/* OPTIONAL: slash separator (kalau markup breadcrumbs pakai item list) */
.kc-hero--dm .kc-breadcrumbs{
  color: rgba(255,255,255,.72);
}
.kc-hero--dm .kc-breadcrumbs a{
  color: rgba(255,255,255,.78);
  text-decoration: none;
}
.kc-hero--dm .kc-breadcrumbs a:hover{
  color: rgba(255,255,255,.95);
}

/* text contrast fixes */
.kc-hero--dm .kc-eyebrow{ color: rgba(255,255,255,.78) !important; }
.kc-hero--dm .kc-lead{ color: rgba(255,255,255,.76) !important; }
.kc-hero--dm .kc-quote{ color: rgba(255,255,255,.80) !important; }
.kc-section--cta .kc-lead{ color: rgba(255,255,255,.78) !important; }

/* layout inside hero */
.kc-hero--dm .kc-hero__grid{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 22px;
}
@media (max-width: 980px){
  .kc-hero--dm .kc-hero__grid{
    grid-template-columns: 1fr;
  }
}

/* SERVICES grid: hover + gradient glow */
.kc-grid--dmServices > *{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
}
.kc-grid--dmServices > *::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(420px 240px at 20% 10%, rgba(255,153,51,.18), transparent 55%),
    radial-gradient(420px 240px at 80% 15%, rgba(0,153,255,.14), transparent 55%);
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.kc-grid--dmServices > *:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
  border-color: rgba(0,0,0,.10);
}
.kc-grid--dmServices > *:hover::before{ opacity: 1; }

/* PROOF grid: hover highlight */
.kc-grid--dmProof .kc-proofcard{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease;
  overflow: hidden;
}
.kc-grid--dmProof .kc-proofcard::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(135deg, rgba(255,153,51,.12), rgba(0,153,255,.10));
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.kc-grid--dmProof .kc-proofcard:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
}
.kc-grid--dmProof .kc-proofcard:hover::after{ opacity: 1; }

/* DELIVERABLES grid: 4 cols desktop, 2 cols mobile */
.kc-grid--dmDeliverables{
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
@media (max-width: 860px){
  .kc-grid--dmDeliverables{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.kc-deliverable{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  padding: 16px;
  transition: transform .18s ease, box-shadow .18s ease;
  overflow: hidden;
}
.kc-deliverable::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(380px 220px at 20% 10%, rgba(255,153,51,.16), transparent 55%),
    radial-gradient(380px 220px at 80% 15%, rgba(0,153,255,.12), transparent 55%);
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.kc-deliverable:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
}
.kc-deliverable:hover::before{ opacity: 1; }

.kc-deliverable__icon{
  width: 42px; height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.04);
  margin-bottom: 10px;
}
.kc-deliverable__icon svg{
  width: 22px; height: 22px;
  fill: currentColor;
  color: rgba(0,0,0,.78);
}

/* FAQ: icon clean + alignment */
.kc-faq__item{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}
.kc-faq__q{
  list-style: none;
  cursor: pointer;
  position: relative;
  padding: 14px 44px 14px 14px;
  font-weight: 700;
}
.kc-faq__q::-webkit-details-marker{ display:none; }
.kc-faq__q::after{
  content:"+";
  position: absolute;
  right: 14px; top: 50%;
  transform: translateY(-50%);
  width: 28px; height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.06);
  color: rgba(0,0,0,.78);
  font-weight: 800;
}
.kc-faq__item[open] .kc-faq__q::after{
  content:"–";
}
.kc-faq__a{
  padding: 0 14px 14px 14px;
  color: rgba(0,0,0,.72);
}

/* CTA contactmini spacing (biar form & panel rapi) */
.kc-grid--contactmini{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: start;
}
@media (max-width: 860px){
  .kc-grid--contactmini{ grid-template-columns: 1fr; }
}
/* =========================================================
   DM SERVICES – Micro-interaction “Signal Chips”
   - muncul saat hover / focus-within
   - aman untuk keyboard + reduced motion
========================================================= */

.kc-grid--dmServices .kc-card--dm{
  position: relative;
}

/* container chips */
.kc-grid--dmServices .kc-signal{
  position: absolute;
  top: 12px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.07);
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 34px rgba(0,0,0,.10);

  opacity: 0;
  transform: translateY(-6px) scale(.98);
  transition: opacity .16s ease, transform .18s ease;
  pointer-events: none; /* biar hover card tetap stabil */
}

/* wide card support (Tracking) */
.kc-grid--dmServices .kc-signal--wide{
  right: auto;
  left: 12px;
}

/* chips */
.kc-signal__chip{
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: rgba(0,0,0,.78);
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.65);
}

/* “good” state = sedikit lebih standout */
.kc-signal__chip--good{
  border-color: rgba(255,140,0,.30);
  background: linear-gradient(135deg, rgba(255,140,0,.18), rgba(0,153,255,.12));
  color: rgba(0,0,0,.82);
}

/* sparkline mini */
.kc-signal__spark{
  width: 28px;
  height: 10px;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(0,0,0,.04);
}
.kc-signal__spark::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,
      rgba(255,140,0,.00) 0%,
      rgba(255,140,0,.35) 35%,
      rgba(0,153,255,.28) 70%,
      rgba(0,153,255,.00) 100%);
  transform: translateX(-60%);
  animation: kcSparkSweep 1.6s ease-in-out infinite;
  opacity: .9;
}

/* show on hover + keyboard focus */
.kc-grid--dmServices .kc-card--dm:hover .kc-signal,
.kc-grid--dmServices .kc-card--dm:focus-within .kc-signal{
  opacity: 1;
  transform: translateY(0) scale(1);
}

@keyframes kcSparkSweep{
  0%{ transform: translateX(-70%); }
  55%{ transform: translateX(70%); }
  100%{ transform: translateX(70%); }
}

/* Reduced motion: matikan sweep & transform berlebihan (aksesibilitas) */
@media (prefers-reduced-motion: reduce){
  .kc-signal{
    transition: opacity .12s ease;
    transform: none !important;
  }
  .kc-signal__spark::before{
    animation: none !important;
    transform: none !important;
    opacity: .55;
  }
}
/* =========================================================
   DIGITAL MARKETING – Fix Kontras + Hover + Signal Tone
========================================================= */

/* HERO: contained, kontras teks aman */
.kc-hero--dm{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(900px 520px at 20% 15%, rgba(255,153,51,.22), transparent 55%),
    radial-gradient(900px 520px at 78% 20%, rgba(0,153,255,.18), transparent 60%),
    linear-gradient(135deg, #0b0f14 0%, #06080c 100%);
}

.kc-hero--dm .kc-eyebrow{ color: rgba(255,255,255,.80) !important; }
.kc-hero--dm .kc-lead{ color: rgba(255,255,255,.78) !important; }
.kc-hero--dm .kc-quote{ color: rgba(255,255,255,.84) !important; }
.kc-hero--dm .kc-muted{ color: rgba(255,255,255,.74) !important; }

.kc-hero--dm .kc-hero__breadcrumbs{ margin-bottom: 14px; }
.kc-hero--dm .kc-breadcrumbs,
.kc-hero--dm .kc-breadcrumbs a{
  color: rgba(255,255,255,.76);
}
.kc-hero--dm .kc-breadcrumbs a:hover{ color: rgba(255,255,255,.95); }

.kc-hero--dm .kc-hero__grid{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 22px;
}
@media (max-width: 980px){
  .kc-hero--dm .kc-hero__grid{
    grid-template-columns: 1fr;
  }
}

/* CTA kontras */
.kc-section--cta .kc-lead{ color: rgba(255,255,255,.78) !important; }

/* SERVICES hover glow */
.kc-grid--dmServices > *{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
}
.kc-grid--dmServices > *::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(420px 240px at 20% 10%, rgba(255,153,51,.18), transparent 55%),
    radial-gradient(420px 240px at 80% 15%, rgba(0,153,255,.14), transparent 55%);
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.kc-grid--dmServices > *:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
  border-color: rgba(0,0,0,.10);
}
.kc-grid--dmServices > *:hover::before{ opacity: 1; }

/* PROOF hover */
.kc-grid--dmProof .kc-proofcard{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease;
  overflow: hidden;
}
.kc-grid--dmProof .kc-proofcard::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(135deg, rgba(255,153,51,.12), rgba(0,153,255,.10));
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.kc-grid--dmProof .kc-proofcard:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
}
.kc-grid--dmProof .kc-proofcard:hover::after{ opacity: 1; }

/* DELIVERABLES: 4 col desktop, 2x2 mobile + hover */
.kc-grid--dmDeliverables{
  display:grid;
  gap:14px;
  grid-template-columns: repeat(4, minmax(0,1fr));
}
@media (max-width: 860px){
  .kc-grid--dmDeliverables{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
.kc-deliverable{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  padding: 16px;
  transition: transform .18s ease, box-shadow .18s ease;
  overflow: hidden;
}
.kc-deliverable::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(380px 220px at 20% 10%, rgba(255,153,51,.16), transparent 55%),
    radial-gradient(380px 220px at 80% 15%, rgba(0,153,255,.12), transparent 55%);
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.kc-deliverable:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
}
.kc-deliverable:hover::before{ opacity: 1; }

.kc-deliverable__icon{
  width: 42px; height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(0,0,0,.04);
  margin-bottom: 10px;
}
.kc-deliverable__icon svg{
  width: 22px; height: 22px;
  fill: currentColor;
  color: rgba(0,0,0,.78);
}

/* FAQ: plus/minus rapi */
.kc-faq__item{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}
.kc-faq__q{
  list-style: none;
  cursor: pointer;
  position: relative;
  padding: 14px 44px 14px 14px;
  font-weight: 800;
}
.kc-faq__q::-webkit-details-marker{ display:none; }
.kc-faq__q::after{
  content:"+";
  position: absolute;
  right: 14px; top: 50%;
  transform: translateY(-50%);
  width: 28px; height: 28px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: rgba(0,0,0,.06);
  color: rgba(0,0,0,.78);
  font-weight: 900;
}
.kc-faq__item[open] .kc-faq__q::after{ content:"–"; }
.kc-faq__a{
  padding: 0 14px 14px 14px;
  color: rgba(0,0,0,.72);
}

/* =========================================================
   SIGNAL CHIPS – Micro-interaction + tone per channel
   Google warm, Meta violet, TikTok cyan, neutral default
========================================================= */

/* Base tokens */
.kc-signal{
  --kc-sig-a: rgba(255,153,51,.22);
  --kc-sig-b: rgba(0,153,255,.12);
  --kc-sig-ink: rgba(0,0,0,.78);
}

/* Channel tones */
.kc-signal--google{
  --kc-sig-a: rgba(255,153,51,.30);   /* warm */
  --kc-sig-b: rgba(255,210,140,.18);
}
.kc-signal--meta{
  --kc-sig-a: rgba(155,81,224,.22);   /* violet */
  --kc-sig-b: rgba(255,153,51,.10);
}
.kc-signal--tiktok{
  --kc-sig-a: rgba(0,220,255,.22);    /* cyan */
  --kc-sig-b: rgba(0,153,255,.14);
}
.kc-signal--neutral{
  --kc-sig-a: rgba(0,0,0,.10);
  --kc-sig-b: rgba(255,153,51,.10);
}

/* Signal container */
.kc-grid--dmServices .kc-card--dm{ position: relative; }

.kc-grid--dmServices .kc-signal{
  position: absolute;
  top: 12px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.07);
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 34px rgba(0,0,0,.10);

  opacity: 0;
  transform: translateY(-6px) scale(.98);
  transition: opacity .16s ease, transform .18s ease;
  pointer-events: none;
}

/* wide support */
.kc-grid--dmServices .kc-signal--wide{
  right: auto;
  left: 12px;
}

/* chips */
.kc-signal__chip{
  display:inline-flex;
  align-items:center;
  height:24px;
  padding:0 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  letter-spacing:-.01em;
  color: var(--kc-sig-ink);
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.65);
}
.kc-signal__chip--good{
  border-color: rgba(0,0,0,.10);
  background: linear-gradient(135deg, var(--kc-sig-a), var(--kc-sig-b));
}

/* sparkline */
.kc-signal__spark{
  width: 28px;
  height: 10px;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(0,0,0,.04);
}
.kc-signal__spark::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(90deg,
    rgba(0,0,0,0) 0%,
    var(--kc-sig-a) 35%,
    var(--kc-sig-b) 70%,
    rgba(0,0,0,0) 100%);
  transform: translateX(-60%);
  animation: kcSparkSweep 1.6s ease-in-out infinite;
  opacity: .95;
}

.kc-grid--dmServices .kc-card--dm:hover .kc-signal,
.kc-grid--dmServices .kc-card--dm:focus-within .kc-signal{
  opacity: 1;
  transform: translateY(0) scale(1);
}

@keyframes kcSparkSweep{
  0%{ transform: translateX(-70%); }
  55%{ transform: translateX(70%); }
  100%{ transform: translateX(70%); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .kc-grid--dmServices .kc-signal{
    transition: opacity .12s ease;
    transform: none !important;
  }
  .kc-signal__spark::before{
    animation: none !important;
    transform: none !important;
    opacity: .55;
  }
}
/* =========================================
   DM PATCH – spacing + swipe mobile + hover
========================================= */

/* 1) PROOF CARD: padding + layout rapi */
.kc-proofcard{
  padding: 18px !important;
}
.kc-proofcard__kpi{ margin: 0 0 10px !important; }
.kc-proofcard__desc{ margin: 0 0 12px !important; }
.kc-proofcard__src{ margin: 0 !important; opacity: .7; font-size: 12px; }

/* 2) PROOF: mobile jadi swipe (horizontal) */
@media (max-width: 860px){
  .kc-grid--dmProof{
    display: flex !important;
    gap: 12px !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 6px;
  }
  .kc-grid--dmProof::-webkit-scrollbar{ display:none; }

  .kc-grid--dmProof .kc-proofcard{
    flex: 0 0 88%;
    scroll-snap-align: start;
  }
}

/* 3) SERVICES: mobile jadi swipe juga (biar ga kepanjangan) */
@media (max-width: 860px){
  .kc-grid--dmServices{
    display: flex !important;
    gap: 12px !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 6px;
  }
  .kc-grid--dmServices::-webkit-scrollbar{ display:none; }

  .kc-grid--dmServices .kc-card--dm{
    flex: 0 0 88%;
    scroll-snap-align: start;
  }

  /* tracking wide card biar lebih “full” */
  .kc-grid--dmServices .kc-card--dmWide{
    flex-basis: 92%;
  }
}

/* 4) WORKFLOW / STEPS: hover biar hidup */
.kc-steps--dm .kc-step{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-steps--dm .kc-step:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
  border-color: rgba(0,0,0,.10);
}

/* 5) CTA panel soft: paksa text gelap (karena section CTA warnanya putih) */
#konsultasi .kc-panel--soft{
  background: #fff !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  color: rgba(0,0,0,.82) !important;
}
#konsultasi .kc-panel--soft .kc-h4,
#konsultasi .kc-panel--soft h1,
#konsultasi .kc-panel--soft h2,
#konsultasi .kc-panel--soft h3,
#konsultasi .kc-panel--soft h4{
  color: rgba(0,0,0,.88) !important;
}
#konsultasi .kc-panel--soft .kc-list,
#konsultasi .kc-panel--soft .kc-list li{
  color: rgba(0,0,0,.78) !important;
}
#konsultasi .kc-panel--soft .kc-muted{
  color: rgba(0,0,0,.66) !important;
}
/* =========================================================
   SEO PAGE – UI/UX Revamp
========================================================= */

/* HERO SEO */
.kc-hero--seo{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(900px 520px at 18% 18%, rgba(46, 204, 113,.18), transparent 55%),
    radial-gradient(900px 520px at 80% 22%, rgba(0, 153, 255,.16), transparent 60%),
    linear-gradient(135deg, #0b0f14 0%, #06080c 100%);
}
.kc-hero--seo .kc-eyebrow{ color: rgba(255,255,255,.80) !important; }
.kc-hero--seo .kc-lead{ color: rgba(255,255,255,.78) !important; }
.kc-hero--seo .kc-quote{ color: rgba(255,255,255,.84) !important; }
.kc-hero--seo .kc-muted{ color: rgba(255,255,255,.74) !important; }

.kc-hero--seo .kc-hero__breadcrumbs{ margin-bottom: 14px; }
.kc-hero--seo .kc-breadcrumbs,
.kc-hero--seo .kc-breadcrumbs a{ color: rgba(255,255,255,.76); }
.kc-hero--seo .kc-breadcrumbs a:hover{ color: rgba(255,255,255,.95); }

.kc-hero--seo .kc-hero__grid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 22px;
}
@media (max-width: 980px){
  .kc-hero--seo .kc-hero__grid{
    grid-template-columns: 1fr;
  }
}

/* Panel kanan */
.kc-panel--seo{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 46px rgba(0,0,0,.25);
}
.kc-panel--seo .kc-h3{ color: rgba(255,255,255,.90) !important; }
.kc-panel--seo .kc-muted{ color: rgba(255,255,255,.75) !important; }

.kc-stacklist{ display: grid; gap: 10px; margin-top: 12px; }
.kc-stackitem{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.kc-stackitem__tag{
  font-size: 12px;
  font-weight: 800;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.85);
  background: rgba(255,255,255,.06);
}
.kc-tag--tech{ background: rgba(46,204,113,.10); }
.kc-tag--content{ background: rgba(255,153,51,.10); }
.kc-tag--schema{ background: rgba(155,81,224,.10); }
.kc-tag--perf{ background: rgba(0,153,255,.10); }
.kc-tag--tools{ background: rgba(255,255,255,.06); }
.kc-stackitem__text{ color: rgba(255,255,255,.78); font-size: 14px; }

/* Pillars grid hover */
.kc-grid--seoPillars > *{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
}
.kc-grid--seoPillars > *::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(420px 240px at 20% 10%, rgba(46,204,113,.16), transparent 55%),
    radial-gradient(420px 240px at 80% 15%, rgba(0,153,255,.12), transparent 55%);
  opacity: 0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.kc-grid--seoPillars > *:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
  border-color: rgba(0,0,0,.10);
}
.kc-grid--seoPillars > *:hover::before{ opacity: 1; }

/* Proof cards padding + hover */
.kc-grid--seoProof .kc-proofcard{
  padding: 18px !important;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease;
  overflow: hidden;
}
.kc-grid--seoProof .kc-proofcard:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
}
.kc-proofcard__kpi{ margin: 0 0 10px !important; font-weight: 900; }
.kc-proofcard__desc{ margin: 0 0 12px !important; }
.kc-proofcard__src{ margin: 0 !important; opacity: .72; font-size: 12px; }

/* Steps hover (SEO) */
.kc-steps--seo .kc-step{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-steps--seo .kc-step:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
  border-color: rgba(0,0,0,.10);
}

/* Deliverables: 4 cols desktop, 2 cols mobile */
.kc-grid--seoDeliverables{
  display:grid;
  gap:14px;
  grid-template-columns: repeat(4, minmax(0,1fr));
}
@media (max-width: 860px){
  .kc-grid--seoDeliverables{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
.kc-deliverable{
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  padding: 16px;
  transition: transform .18s ease, box-shadow .18s ease;
  overflow: hidden;
}
.kc-deliverable:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
}
.kc-deliverable__icon{
  width: 42px; height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(0,0,0,.04);
  margin-bottom: 10px;
}
.kc-deliverable__icon svg{
  width: 22px; height: 22px;
  fill: currentColor;
  color: rgba(0,0,0,.78);
}

/* Tools cards */
.kc-grid--seoTools{
  display:grid;
  gap:14px;
  grid-template-columns: repeat(4, minmax(0,1fr));
}
@media (max-width: 980px){
  .kc-grid--seoTools{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
.kc-toolcard{
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  padding: 16px;
  transition: transform .18s ease, box-shadow .18s ease;
}
.kc-toolcard:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 46px rgba(0,0,0,.12);
}

/* FAQ: plus/minus rapi */
.kc-faq__item{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}
.kc-faq__q{
  list-style: none;
  cursor: pointer;
  position: relative;
  padding: 14px 44px 14px 14px;
  font-weight: 800;
}
.kc-faq__q::-webkit-details-marker{ display:none; }
.kc-faq__q::after{
  content:"+";
  position: absolute;
  right: 14px; top: 50%;
  transform: translateY(-50%);
  width: 28px; height: 28px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: rgba(0,0,0,.06);
  color: rgba(0,0,0,.78);
  font-weight: 900;
}
.kc-faq__item[open] .kc-faq__q::after{ content:"–"; }
.kc-faq__a{ padding: 0 14px 14px 14px; color: rgba(0,0,0,.72); }

/* CTA text on dark section */
.kc-section--cta .kc-lead{ color: rgba(255,255,255,.78) !important; }

/* CTA panel soft: force dark text */
#konsultasi .kc-panel--soft{
  background: #fff !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  color: rgba(0,0,0,.82) !important;
}
#konsultasi .kc-panel--soft .kc-h4,
#konsultasi .kc-panel--soft h1,
#konsultasi .kc-panel--soft h2,
#konsultasi .kc-panel--soft h3,
#konsultasi .kc-panel--soft h4{
  color: rgba(0,0,0,.88) !important;
}
#konsultasi .kc-panel--soft .kc-list,
#konsultasi .kc-panel--soft .kc-list li{
  color: rgba(0,0,0,.78) !important;
}
#konsultasi .kc-panel--soft .kc-muted{ color: rgba(0,0,0,.66) !important; }

/* =========================================================
   SIGNAL CHIPS – tone SEO per pillar
========================================================= */
.kc-signal{
  --kc-sig-a: rgba(46,204,113,.18);
  --kc-sig-b: rgba(0,153,255,.12);
  --kc-sig-ink: rgba(0,0,0,.78);
}
.kc-signal--seoTech{
  --kc-sig-a: rgba(46,204,113,.24);
  --kc-sig-b: rgba(46,204,113,.10);
}
.kc-signal--seoContent{
  --kc-sig-a: rgba(255,153,51,.22);
  --kc-sig-b: rgba(46,204,113,.10);
}
.kc-signal--seoSchema{
  --kc-sig-a: rgba(155,81,224,.22);
  --kc-sig-b: rgba(0,153,255,.12);
}
.kc-signal--seoTools{
  --kc-sig-a: rgba(0,153,255,.20);
  --kc-sig-b: rgba(255,255,255,.0);
}

.kc-grid--seoPillars .kc-card--seo{ position: relative; }
.kc-grid--seoPillars .kc-signal{
  position: absolute;
  top: 12px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.07);
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 34px rgba(0,0,0,.10);
  opacity: 0;
  transform: translateY(-6px) scale(.98);
  transition: opacity .16s ease, transform .18s ease;
  pointer-events: none;
}
.kc-signal__chip{
  display:inline-flex;
  align-items:center;
  height:24px;
  padding:0 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  letter-spacing:-.01em;
  color: var(--kc-sig-ink);
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.65);
}
.kc-signal__chip--good{
  border-color: rgba(0,0,0,.10);
  background: linear-gradient(135deg, var(--kc-sig-a), var(--kc-sig-b));
}
.kc-signal__spark{
  width: 28px;
  height: 10px;
  border-radius: 999px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(0,0,0,.04);
}
.kc-signal__spark::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(90deg,
    rgba(0,0,0,0) 0%,
    var(--kc-sig-a) 35%,
    var(--kc-sig-b) 70%,
    rgba(0,0,0,0) 100%);
  transform: translateX(-60%);
  animation: kcSparkSweep 1.6s ease-in-out infinite;
  opacity: .95;
}
.kc-grid--seoPillars .kc-card--seo:hover .kc-signal,
.kc-grid--seoPillars .kc-card--seo:focus-within .kc-signal{
  opacity: 1;
  transform: translateY(0) scale(1);
}
@keyframes kcSparkSweep{
  0%{ transform: translateX(-70%); }
  55%{ transform: translateX(70%); }
  100%{ transform: translateX(70%); }
}
@media (prefers-reduced-motion: reduce){
  .kc-grid--seoPillars .kc-signal{ transition: opacity .12s ease; transform: none !important; }
  .kc-signal__spark::before{ animation: none !important; transform: none !important; opacity: .55; }
}

/* =========================================================
   MOBILE SWIPE – pillars, proof, tools (biar ga panjang)
========================================================= */
@media (max-width: 860px){
  .kc-grid--seoPillars,
  .kc-grid--seoProof,
  .kc-grid--seoTools{
    display:flex !important;
    gap:12px !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 6px;
  }
  .kc-grid--seoPillars::-webkit-scrollbar,
  .kc-grid--seoProof::-webkit-scrollbar,
  .kc-grid--seoTools::-webkit-scrollbar{ display:none; }

  .kc-grid--seoPillars > *,
  .kc-grid--seoProof > *,
  .kc-grid--seoTools > *{
    flex: 0 0 88%;
    scroll-snap-align: start;
  }
}
/* =========================================
   SEO FIX – Contrast + Desktop Grids + Proof Icons + Steps Mobile
========================================= */

/* (A) HERO SEO: pastikan H1 & bullets kebaca (override default hitam) */
.kc-hero--seo .kc-h1{
  color: rgba(255,255,255,.94) !important;
}
.kc-hero--seo .kc-seoHero__bullets,
.kc-hero--seo .kc-seoHero__bullets li{
  color: rgba(255,255,255,.78) !important;
}
.kc-hero--seo .kc-seoHero__bullets .kc-dot{
  background: rgba(255,255,255,.55) !important;
}

/* (B) PILAR: desktop 4 card jadi 2 kolom x 2 baris */
@media (min-width: 861px){
  .kc-grid--seoPillars{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
  }
}

/* (C) PROOF: desktop 3 card sebaris */
@media (min-width: 861px){
  .kc-grid--seoProof{
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 14px !important;
  }
}

/* (D) PROOF: ikon + spacing rapi */
.kc-grid--seoProof .kc-proofcard{
  position: relative;
  padding: 18px !important;
}
.kc-proofcard__icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.04);
  margin-bottom: 10px;
  border: 1px solid rgba(0,0,0,.06);
}
.kc-proofcard__icon svg{
  width: 22px;
  height: 22px;
  stroke: rgba(0,0,0,.78);
}

/* (E) STEPS SEO: mobile 2 kolom x 2 baris */
@media (max-width: 860px){
  .kc-steps--seo{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }
  .kc-steps--seo .kc-step{
    padding: 14px !important;
  }
  .kc-steps--seo .kc-step__num{
    transform: scale(.92);
  }
}
/* =========================================
   SEO HERO – Chips mobile: jangan dipaksa shrink
========================================= */

.kc-chips--seo{
  /* amanin container swipe */
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 2px 2px 8px;
}

/* penting: chip harus ikut panjang teks */
.kc-chips--seo .kc-chip{
  flex: 0 0 auto !important;        
  width: auto !important;           
  max-width: none !important;       
  white-space: nowrap !important;   
  line-height: 1.05;                
}

/* optional: sedikit lebih enak di layar kecil */
@media (max-width: 520px){
  .kc-chips--seo .kc-chip{
    font-size: 12px;
    padding: 9px 11px;
  }
}
/* =========================================
   SEO HERO – Stack item glow per tag (no HTML changes)
   Uses :has() to detect tag inside each item
========================================= */

.kc-panel--seo .kc-stackitem{
  /* default glow (netral) */
  --kc-ov-a: rgba(255,255,255,.10);
  --kc-ov-b: rgba(255,255,255,.04);

  position: relative;
  overflow: hidden;
  transition: transform .16s ease, border-color .16s ease;
}

.kc-panel--seo .kc-stackitem::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(420px 160px at 15% 20%, var(--kc-ov-a), transparent 58%),
    radial-gradient(420px 160px at 85% 25%, var(--kc-ov-b), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  opacity: 0;
  transition: opacity .16s ease;
  pointer-events:none;
}

.kc-panel--seo .kc-stackitem:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.18);
}
.kc-panel--seo .kc-stackitem:hover::after{ opacity: 1; }

/* konten di atas overlay */
.kc-panel--seo .kc-stackitem > *{ position: relative; z-index: 1; }

/* keyboard focus juga dapet glow */
.kc-panel--seo .kc-stackitem:focus-within{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.18);
}
.kc-panel--seo .kc-stackitem:focus-within::after{ opacity: 1; }

/* ===== Tag-based tones (modern browsers) ===== */
@supports selector(:has(*)){
  .kc-panel--seo .kc-stackitem:has(.kc-tag--tech){
    --kc-ov-a: rgba(46,204,113,.22);     /* green */
    --kc-ov-b: rgba(0,153,255,.14);
  }
  .kc-panel--seo .kc-stackitem:has(.kc-tag--content){
    --kc-ov-a: rgba(255,153,51,.22);     /* warm/orange */
    --kc-ov-b: rgba(46,204,113,.10);
  }
  .kc-panel--seo .kc-stackitem:has(.kc-tag--schema){
    --kc-ov-a: rgba(155,81,224,.24);     /* violet */
    --kc-ov-b: rgba(0,153,255,.14);
  }
  .kc-panel--seo .kc-stackitem:has(.kc-tag--perf){
    --kc-ov-a: rgba(0,153,255,.22);      /* blue */
    --kc-ov-b: rgba(46,204,113,.10);
  }
  .kc-panel--seo .kc-stackitem:has(.kc-tag--tools){
    --kc-ov-a: rgba(255,255,255,.14);    /* neutral */
    --kc-ov-b: rgba(255,153,51,.10);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .kc-panel--seo .kc-stackitem{
    transition: border-color .12s ease;
    transform: none !important;
  }
  .kc-panel--seo .kc-stackitem::after{
    transition: opacity .12s ease;
  }
}
/* =========================================
   SEO HERO – Chips: swipe only on mobile
========================================= */

/* Desktop/tablet: jangan swipe, jangan scrollbar */
@media (min-width: 861px){
  .kc-chips--seo{
    overflow: visible !important;
    flex-wrap: wrap !important;
    -webkit-overflow-scrolling: auto;
    scroll-snap-type: none;
    padding-bottom: 0 !important;
  }
  /* jaga kalau ada rule lain yang bikin scrollbar tampil */
  .kc-chips--seo::-webkit-scrollbar{ height: 0 !important; display: none !important; }
}

/* Mobile: baru swipe */
@media (max-width: 860px){
  .kc-chips--seo{
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 8px !important;
  }
  .kc-chips--seo::-webkit-scrollbar{ display:none; }

  .kc-chips--seo .kc-chip{
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }
}

/* =========================
   HOME — HERO desktop grid fix
   ========================= */
@media (min-width: 980px){
  /* scope ke homepage biar aman */
  .home .kc-hero{
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    gap: 34px;
    align-items: center;
  }

  /* pastikan right gak kebawa margin mobile */
  .home .kc-hero__right{
    margin-top: 0 !important;
  }

  /* cegah teks “nabrak” container karena kata panjang / layout */
  .home .kc-hero__left .kc-h1,
  .home .kc-hero__left .kc-lead{
    max-width: 60ch;
    overflow-wrap: anywhere;
  }
}
/* =========================
   HOME — ABOUT chips contrast + mobile swipe
   ========================= */

/* default (desktop/tablet): wrap normal, teks gelap */
.home .kc-about__chips{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.home .kc-about__chips .kc-chip{
  color: rgba(11,18,32,.82) !important;
  background: rgba(11,18,32,.06);
  border: 1px solid rgba(11,18,32,.10);
}

.home .kc-about__chips .kc-chip:hover{
  background: rgba(11,18,32,.09);
  border-color: rgba(11,18,32,.14);
}

/* mobile: swipe */
@media (max-width: 480px){
  .home .kc-about__chips{
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding: 2px 2px 10px;
    gap:5px;
  }
  .home .kc-about__chips::-webkit-scrollbar{ display:none; }

  .home .kc-about__chips .kc-chip{
    flex: 0 0 auto;
    white-space: nowrap;
    scroll-snap-align: start;
    font-size:12px;
  }
}
/* =========================
   BENEFITS — proofchips (mobile swipe + readable)
   taruh PALING BAWAH components.css
   ========================= */

/* Kontras chip biar kebaca (semua ukuran) */
.kc-section--benefits .kc-proofchips .kc-proofchip{
  color: rgba(11,18,32,.82) !important;
  background: rgba(11,18,32,.06) !important;
  border: 1px solid rgba(11,18,32,.10) !important;
}

/* Mobile swipe */
@media (max-width: 860px){
  .kc-section--benefits .kc-proofchips{
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding: 2px 2px 10px !important;
    gap: 20px !important;
    margin-top: 25px;
  }

  .kc-section--benefits .kc-proofchips::-webkit-scrollbar{
    display: none;
  }
  .kc-section--benefits .kc-proofchips{
    scrollbar-width: none; /* Firefox */
  }

  .kc-section--benefits .kc-proofchips .kc-proofchip{
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    scroll-snap-align: start;
  }
}
/* =========================================
   SERVICES HUB (/layanan-kami/)
   Fix hero grid + rail scrollbar + services carousel
   taruh PALING BAWAH components.css
   ========================================= */

/* 1) HERO: paksa 2 kolom di desktop */
@media (min-width: 980px){
  .kc-section--serviceshub .kc-hero{
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 32px;
    align-items: start;
  }

  .kc-section--serviceshub .kc-hero__right{
    margin-top: 0 !important;
  }

  /* jaga teks gak “melebar” */
  .kc-section--serviceshub .kc-hero__left .kc-h1,
  .kc-section--serviceshub .kc-hero__left .kc-lead{
    max-width: 62ch;
    overflow-wrap: anywhere;
  }
}

/* 2) SERVICES RAIL: tetap bisa scroll, tapi scrollbar hilang */
@media (min-width: 992px){
  .kc-section--serviceshub .kc-servicesRail{
    overflow: auto;            /* tetap scrollable */
    scrollbar-width: none;     /* Firefox */
  }
  .kc-section--serviceshub .kc-servicesRail::-webkit-scrollbar{
    width: 0;
    height: 0;                /* Chrome/Safari */
  }
}

/* 3) SERVICES GRID: jadikan “carousel” swipe (desktop + mobile) */
.kc-grid--services.kc-servicesGrid{
  display: flex !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  gap: 16px !important;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 10px;
  scrollbar-width: none; /* Firefox */
}
.kc-grid--services.kc-servicesGrid::-webkit-scrollbar{ display:none; }

/* setiap card jadi item geser */
.kc-grid--services.kc-servicesGrid > .kc-card{
  flex: 0 0 auto;
  scroll-snap-align: start;
}

/* desktop: tampil 3 card “sebaris”, sisanya swipe */
@media (min-width: 1024px){
  .kc-grid--services.kc-servicesGrid > .kc-card{
    width: min(360px, calc((100% - 32px) / 3));
  }
}

/* tablet: tampil 2 card, sisanya swipe */
@media (min-width: 640px) and (max-width: 1023px){
  .kc-grid--services.kc-servicesGrid > .kc-card{
    width: min(360px, calc((100% - 16px) / 2));
  }
}

/* mobile: 1 card besar, enak di-swipe */
@media (max-width: 639px){
  .kc-grid--services.kc-servicesGrid > .kc-card{
    width: 88%;
  }
}
/* Nav tombol carousel services: tampil desktop aja */
@media (max-width: 860px){
  .kc-servicesGrid__header{ display:none; }
}
/* Services carousel feel: grab cursor */
.kc-grid--services.kc-servicesGrid{
  cursor: grab;
}

.kc-grid--services.kc-servicesGrid.is-dragging{
  cursor: grabbing;
  user-select: none;
}
/* =========================================================
   INSIGHT HUB + SEARCH HUB (scoped, no-conflict)
   ========================================================= */

.kc-visuallyHidden{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.kc-insightHub{ padding-top: 8px; }
.kc-searchHub{ padding-top: 8px; }

.kc-insightHero{
  border: 1px solid rgba(148,163,184,.22);
  border-radius: 22px;
  padding: 22px;
  margin: 10px 0 22px;
  background:
    radial-gradient(520px 240px at 10% 10%, rgba(17,141,201,.10), transparent 60%),
    radial-gradient(520px 240px at 90% 35%, rgba(249,178,22,.12), transparent 60%),
    rgba(255,255,255,.92);
  box-shadow: 0 22px 60px rgba(15,23,42,.08);
}

.kc-insightHero__eyebrow{
  margin: 0 0 6px;
  font-weight: 900;
  letter-spacing: -.01em;
  color: rgba(11,18,32,.72);
  text-transform: uppercase;
  font-size: 12px;
}

.kc-insightHero__title{
  margin: 0 0 10px;
  letter-spacing: -.02em;
}

.kc-insightHero__lead{
  margin: 0 0 16px;
  color: rgba(11,18,32,.72);
  max-width: 68ch;
}

.kc-insightSearch{ margin-top: 6px; }
.kc-insightSearch__box{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 10px 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 45px rgba(15,23,42,.08);
}

.kc-insightSearch__icon{
  width: 18px; height: 18px;
  color: rgba(11,18,32,.55);
  display:grid; place-items:center;
}
.kc-insightSearch__icon svg{ width:18px; height:18px; }

.kc-insightSearch__input{
  flex: 1 1 auto;
  border: 0;
  outline: none;
  background: transparent;
  font-size: 15px;
  color: rgba(11,18,32,.88);
  min-width: 0;
}

.kc-insightSearch__btn{
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
}

.kc-insightHero__chips{
  margin-top: 12px;
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
}

.kc-insightChip{
  display:inline-flex;
  align-items:center;
  padding: 8px 12px;
  border-radius: 999px;
  text-decoration:none;
  font-weight: 800;
  font-size: 13px;
  color: rgba(11,18,32,.78);
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.72);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-insightChip:hover{
  transform: translateY(-1px);
  border-color: rgba(17,141,201,.22);
  box-shadow: 0 16px 42px rgba(15,23,42,.10);
}

/* Layout: main + sidebar */
.kc-insightHub__layout{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 18px;
  align-items: start;
}

.kc-insightHub__side{
  display: grid;
  gap: 16px;
}

.kc-insightSide{
  padding: 16px;
  border-radius: 18px;
}

.kc-insightSide__title{
  margin: 0 0 12px;
}

.kc-insightCats{
  display:grid;
  gap: 10px;
}

.kc-insightCat{
  display:flex;
  align-items:center;
  justify-content: space-between;
  text-decoration:none;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.78);
  color: rgba(11,18,32,.82);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-insightCat em{
  font-style: normal;
  font-weight: 900;
  font-size: 12px;
  color: rgba(11,18,32,.55);
}
.kc-insightCat:hover{
  transform: translateY(-1px);
  border-color: rgba(249,178,22,.28);
  box-shadow: 0 18px 46px rgba(15,23,42,.10);
}

.kc-insightSide__list{ display:grid; gap: 10px; }

.kc-insightMini{
  display:block;
  text-decoration:none;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.78);
  color: rgba(11,18,32,.84);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.kc-insightMini:hover{
  transform: translateY(-1px);
  border-color: rgba(17,141,201,.22);
  box-shadow: 0 18px 46px rgba(15,23,42,.10);
}
.kc-insightMini__badge{
  display:inline-flex;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.72);
  margin-bottom: 8px;
}
.kc-insightMini__title{
  display:block;
  line-height: 1.28;
  letter-spacing: -.01em;
}
.kc-insightMini__meta{
  display:block;
  margin-top: 6px;
  font-size: 12px;
  color: rgba(11,18,32,.60);
}

.kc-insightMuted{ color: rgba(11,18,32,.62); }

.kc-insightBlock{ margin-bottom: 18px; }
.kc-insightBlock__head{ margin: 0 0 14px; }
.kc-insightBlock__head--row{
  display:flex;
  align-items:flex-end;
  justify-content: space-between;
  gap: 12px;
}

.kc-insightList{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.kc-insightPagination{
  margin-top: 18px;
}

/* Search empty box */
.kc-searchEmpty{ padding: 18px; border-radius: 18px; }

/* Responsive */
@media (max-width: 1024px){
  .kc-insightHub__layout{ grid-template-columns: minmax(0,1fr); }
  .kc-insightList{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px){
  .kc-insightHero{ padding: 16px; border-radius: 18px; }
  .kc-insightList{ grid-template-columns: 1fr; }
  .kc-insightSearch__btn{ padding: 10px 12px; }
}
/* =========================================================
   INSIGHT: Search Suggest + Filters (scoped)
   ========================================================= */

.kc-insightSearch{ position: relative; }

.kc-insightSearch__clear{
  border: 0;
  background: transparent;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: rgba(11,18,32,.55);
}
.kc-insightSearch__clear:hover{
  background: rgba(15,23,42,.06);
  color: rgba(11,18,32,.75);
}
.kc-insightSearch__clear svg{ width: 18px; height: 18px; }

.kc-insightSuggest{
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 10px);
  z-index: 30;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  box-shadow: 0 28px 70px rgba(15,23,42,.14);
  padding: 10px;
}

.kc-insightSuggest__section{ padding: 8px; }
.kc-insightSuggest__title{
  font-size: 12px;
  font-weight: 900;
  color: rgba(11,18,32,.62);
  margin: 4px 6px 10px;
  text-transform: uppercase;
}

.kc-insightSuggest__items{
  display: grid;
  gap: 8px;
}

.kc-insightSuggest__item{
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 10px 10px;
  border-radius: 14px;
  text-decoration: none;
  border: 1px solid rgba(148,163,184,.20);
  background: rgba(255,255,255,.72);
  color: rgba(11,18,32,.84);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.kc-insightSuggest__item:hover{
  transform: translateY(-1px);
  border-color: rgba(17,141,201,.22);
  box-shadow: 0 16px 42px rgba(15,23,42,.12);
}
.kc-insightSuggest__item svg{ width: 16px; height: 16px; opacity: .65; }
.kc-insightSuggest__meta{
  margin-left: auto;
  font-size: 12px;
  color: rgba(11,18,32,.58);
}

/* Filter bar */
.kc-insightFilters{
  margin-top: 14px;
  display: flex;
  justify-content: flex-start;
}

.kc-insightFilters__form{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.78);
  box-shadow: 0 18px 46px rgba(15,23,42,.10);
}

.kc-insightFilters__select{
  border-radius: 14px;
  border: 1px solid rgba(148,163,184,.26);
  background: rgba(255,255,255,.92);
  padding: 10px 12px;
  font-weight: 800;
  color: rgba(11,18,32,.80);
  outline: none;
}

/* Mobile: chips jadi swipe (optional, biar rapi) */
@media (max-width: 860px){
  .kc-insightHero__chips{
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding: 2px 2px 10px;
  }
  .kc-insightHero__chips::-webkit-scrollbar{ display:none; }
  .kc-insightChip{ flex: 0 0 auto; white-space: nowrap; scroll-snap-align: start; }
}
/* ================================
   INSIGHT spacing top (scoped)
   ================================ */
.kc-section.kc-insightHub{
  padding-top: 80px;
}
.kc-insightHero{
  margin-top: 14px;
}
/* =========================================
   INSIGHT + SEARCH: compact cards vertical
   (NO-CONFLICT: scoped)
   ========================================= */

.kc-insightHub .kc-card--post-compact .kc-card__link,
.kc-searchHub  .kc-card--post-compact .kc-card__link{
  display: flex !important;
  flex-direction: column !important;
  height: 100%;
}

/* cover di atas + ratio konsisten */
.kc-insightHub .kc-card--post-compact .kc-card__cover,
.kc-searchHub  .kc-card--post-compact .kc-card__cover{
  width: 100% !important;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 16px;
}

.kc-insightHub .kc-card--post-compact .kc-card__cover img,
.kc-searchHub  .kc-card--post-compact .kc-card__cover img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* body rapih */
.kc-insightHub .kc-card--post-compact .kc-card__body,
.kc-searchHub  .kc-card--post-compact .kc-card__body{
  padding: 12px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* clamp biar gak memanjang kebawah */
.kc-insightHub .kc-card--post-compact .kc-card__title,
.kc-searchHub  .kc-card--post-compact .kc-card__title{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.kc-insightHub .kc-card--post-compact .kc-card__desc--compact,
.kc-searchHub  .kc-card--post-compact .kc-card__desc--compact{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}
.kc-insightHub .kc-insightList,
.kc-searchHub  .kc-searchList{
  align-items: stretch;
}
.kc-insightHub .kc-card--post-compact,
.kc-searchHub  .kc-card--post-compact{
  height: 100%;
}
/* =========================================
   INSIGHT/SEARCH — compact card size FIX
   (keep image on top but NOT huge)
   ========================================= */

/* 1) Global compact sizing di Insight/Search */
.kc-insightHub .kc-card--post-compact .kc-card__cover,
.kc-searchHub  .kc-card--post-compact .kc-card__cover{
  aspect-ratio: 16 / 10;          /* lebih pendek dari 16/9 */
  max-height: 160px;               /* kunci biar gak jumbo */
  border-radius: 16px;
}

.kc-insightHub .kc-card--post-compact .kc-card__body,
.kc-searchHub  .kc-card--post-compact .kc-card__body{
  padding: 10px 12px 12px;
  gap: 6px;
}

.kc-insightHub .kc-card--post-compact .kc-card__title,
.kc-searchHub  .kc-card--post-compact .kc-card__title{
  font-size: 14px;
  line-height: 1.22;
  -webkit-line-clamp: 2;
}

.kc-insightHub .kc-card--post-compact .kc-card__desc,
.kc-searchHub  .kc-card--post-compact .kc-card__desc,
.kc-insightHub .kc-card--post-compact .kc-card__desc--compact,
.kc-searchHub  .kc-card--post-compact .kc-card__desc--compact{
  -webkit-line-clamp: 2;          /* pendekin biar gak tinggi */
}

/* 2) Highlight: compact di side & bottom lebih mini lagi */
.kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__cover,
.kc-insightHub .kc-posts-bottom .kc-card--post-compact .kc-card__cover{
  aspect-ratio: 16 / 8;
  max-height: 140px;
}

/* 3) Pastikan compact gak ikut “stretch” jadi tinggi */
.kc-insightHub .kc-posts-side,
.kc-insightHub .kc-posts-bottom{
  align-content: start;
}

.kc-insightHub .kc-posts-side .kc-card--post-compact,
.kc-insightHub .kc-posts-bottom .kc-card--post-compact{
  height: auto;
}

/* 4) Mobile: biar cover tetap enak */
@media (max-width: 640px){
  .kc-insightHub .kc-card--post-compact .kc-card__cover,
  .kc-searchHub  .kc-card--post-compact .kc-card__cover{
    max-height: none;
    aspect-ratio: 16 / 9;
  }
}
/* =========================================
   INSIGHT Highlight: right side cards = mini (no desc)
   ========================================= */

/* 1) Hide desc only inside kc-posts-side */
.kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__desc,
.kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__desc--compact{
  display: none !important;
}

/* 2) Make side cards compact & consistent height */
.kc-insightHub .kc-posts-side{
  display: grid;
  gap: 14px;
  align-content: start;
}

.kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__cover{
  aspect-ratio: 16 / 9;
  max-height: 140px;
}

.kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__body{
  padding: 0;
}

/* clamp title so height stays stable */
.kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__title{
  font-size: 14px;
  line-height: 1.22;
  -webkit-line-clamp: 2;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

/* meta optional: keep, but subtle + single line */
.kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__meta{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(11,18,32,.58);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* =========================================
   INSIGHT — Mobile fix (Highlight swipe + list grid)
   ========================================= */
@media (max-width: 768px){

  /* spacing biar gak sempit */
  .kc-insightHub{ padding-top: 14px; }
  .kc-insightBlock{ margin-bottom: 16px; }

  /* --- HIGHLIGHT: jadi swipe track yang rapi --- */
  .kc-insightHub .kc-posts-layout{ 
    display: block;
  }

  /* Top container jadi horizontal swipe */
  .kc-insightHub .kc-posts-top{
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding: 6px 2px 12px;
    scrollbar-width: none;
  }
  .kc-insightHub .kc-posts-top::-webkit-scrollbar{ display:none; }

  /* Featured & compact di swipe punya lebar seragam */
  .kc-insightHub .kc-posts-top > .kc-card,
  .kc-insightHub .kc-posts-top > .kc-posts-side,
  .kc-insightHub .kc-posts-top > .kc-posts-bottom{
    flex: 0 0 auto !important;
  }

  /* Featured card di mobile: jangan jumbo */
  .kc-insightHub .kc-posts-top .kc-card--post-featured{
    width: 84vw;
    max-width: 360px;
    scroll-snap-align: start;
  }
  .kc-insightHub .kc-posts-top .kc-card--post-featured .kc-card__cover{
    aspect-ratio: 16 / 9;
    max-height: 190px;
  }
  .kc-insightHub .kc-posts-top .kc-card--post-featured .kc-card__desc{
    display: none; /* biar tinggi stabil */
  }
  .kc-insightHub .kc-posts-top .kc-card--post-featured .kc-card__title{
    font-size: 15px;
    line-height: 1.22;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
  }

  /* Side di mobile: jangan grid 2 baris, jadikan list horizontal */
  .kc-insightHub .kc-posts-side{
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    align-items: stretch;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* Bottom di mobile: gabung jadi horizontal juga */
  .kc-insightHub .kc-posts-bottom{
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    align-items: stretch;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* Compact card di mobile highlight: ukurannya seragam */
  .kc-insightHub .kc-posts-side .kc-card--post-compact,
  .kc-insightHub .kc-posts-bottom .kc-card--post-compact{
    width: 84vw;
    max-width: 320px;
    scroll-snap-align: start;
  }

  .kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__cover,
  .kc-insightHub .kc-posts-bottom .kc-card--post-compact .kc-card__cover{
    aspect-ratio: 16 / 9;
    max-height: 170px;
  }

  /* Supaya “mini” dan tinggi stabil: desc off, title clamp */
  .kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__desc,
  .kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__desc--compact,
  .kc-insightHub .kc-posts-bottom .kc-card--post-compact .kc-card__desc,
  .kc-insightHub .kc-posts-bottom .kc-card--post-compact .kc-card__desc--compact{
    display: none !important;
  }

  .kc-insightHub .kc-posts-side .kc-card--post-compact .kc-card__title,
  .kc-insightHub .kc-posts-bottom .kc-card--post-compact .kc-card__title{
    font-size: 14px;
    line-height: 1.22;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
  }

  /* --- SEMUA INSIGHT: grid 2 kolom rapi --- */
  .kc-insightHub .kc-insightList{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  /* Compact di list: jangan tinggi banget */
  .kc-insightHub .kc-insightList .kc-card--post-compact .kc-card__cover{
    aspect-ratio: 4 / 3;
    max-height: 120px;
  }

  .kc-insightHub .kc-insightList .kc-card--post-compact .kc-card__desc,
  .kc-insightHub .kc-insightList .kc-card--post-compact .kc-card__desc--compact{
    display: none; /* 2 kolom butuh ringkas */
  }

  .kc-insightHub .kc-insightList .kc-card--post-compact .kc-card__title{
    font-size: 13.5px;
    line-height: 1.2;
    -webkit-line-clamp: 2;
  }

  .kc-insightHub .kc-insightList .kc-card--post-compact .kc-card__meta{
    font-size: 11.5px;
  }
}

/* extra small: 1 kolom biar lega */
@media (max-width: 420px){
  .kc-insightHub .kc-insightList{
    grid-template-columns: 1fr !important;
  }
  .kc-lead{
      line-height: 1.2;
  }
}
/* FORCE: Insight list jadi 2 kolom di mobile */
@media (max-width: 768px){
  .kc-insightHub .kc-insightBlock .kc-insightList{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
    width: 100%;
  }

  /* pastikan child card tidak dipaksa full width oleh style lain */
  .kc-insightHub .kc-insightBlock .kc-insightList > *{
    width: auto !important;
    min-width: 0 !important;
  }
}

/* extra small biar tetap readable */
@media (max-width: 320px){
  .kc-insightHub .kc-insightBlock .kc-insightList{
    grid-template-columns: 1fr !important;
  }
}
/* Default posts-layout behavior (non-home): jangan bikin kolom kanan ikut "ketarik" tinggi */
.kc-posts-top{ align-items: start; }
.kc-posts-side{
  align-content: start;
  grid-auto-rows: max-content;
}
.kc-card--post-compact{ height: auto; }
.kc-card--post-compact .kc-card__link{ align-items: start; }

/* =========================================================
   INSIGHT (Home) — Desktop alignment
   Biar kolom kanan sejajar tinggi dengan featured + layout compact
   ========================================================= */
@media (min-width: 769px){
  /* kolom kanan ikut setinggi featured */
  #insight .kc-posts-top{ align-items: stretch; }

  /* 2 kartu kanan bagi tinggi sama rata */
  #insight .kc-posts-side{
    grid-template-rows: repeat(2, minmax(0, 1fr));
    align-content: stretch;
  }

  /* compact card di sisi kanan: gambar di atas (bigger), body di bawah */
  #insight .kc-posts-side .kc-card--post-compact,
  #insight .kc-posts-side .kc-card--post-compact .kc-card__link{
    height: 100%;
  }

  #insight .kc-posts-side .kc-card--post-compact .kc-card__link{
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto;
    gap: 0;
    align-items: stretch;
  }

  #insight .kc-posts-side .kc-card--post-compact .kc-card__cover{
    height: 100%;
    min-height: 0;
    aspect-ratio: auto; /* ikut tinggi 1fr */
    border-radius: 16px;
  }

  #insight .kc-posts-side .kc-card--post-compact .kc-card__cover img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  #insight .kc-posts-side .kc-card--post-compact .kc-card__body{
    padding: 12px 12px 14px;
  }

  /* biar rapi dan konsisten tinggi (opsional) */
  #insight .kc-posts-side .kc-card--post-compact .kc-card__desc,
  #insight .kc-posts-side .kc-card--post-compact .kc-card__desc--compact{
    display: none;
  }
}
/* =========================================================
   INSIGHT (Home) — Fix featured empty space:
   cover jadi 1fr (ngisi tinggi card), body auto
   ========================================================= */
@media (min-width: 769px){
  #insight .kc-card--post-featured,
  #insight .kc-card--post-featured .kc-card__link{
    height: 100%;
  }

  #insight .kc-card--post-featured .kc-card__link{
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto; /* cover fleksibel, body nempel bawah */
    align-items: stretch;
  }

  #insight .kc-card--post-featured .kc-card__cover{
    height: 100%;
    min-height: 0;
    aspect-ratio: auto; /* override ratio lama biar bisa stretch */
    border-radius: 18px;
    overflow: hidden;
  }

  #insight .kc-card--post-featured .kc-card__cover img{
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
/* ===============================
   Single Article (layout + media)
   =============================== */

/* Make the article column feel consistent & not "menyempit" */
.kc-article .kc-article__head,
.kc-article .kc-figure,
.kc-article .kc-toc,
.kc-article .kc-quickSummary,
.kc-article .kc-prose,
.kc-article .kc-share,
.kc-article .kc-related,
.kc-article .kc-faq,
.kc-article #comments,
.kc-article .comment-respond{
  margin-left: auto;
  margin-right: auto;
}

.kc-article .kc-prose{
  width: 100%;
  font-size: 1.02rem;
}

/* WordPress caption/figure sometimes injects inline width that breaks layout */
.kc-prose figure,
.kc-prose .wp-caption,
.kc-prose .wp-caption.alignnone,
.kc-prose .wp-caption.aligncenter,
.kc-prose .wp-caption.alignleft,
.kc-prose .wp-caption.alignright{
  max-width: 100% !important;
  width: auto !important;
}

.kc-prose img,
.kc-prose figure img,
.kc-prose video,
.kc-prose iframe{
  max-width: 100%;
  height: auto;
}

.kc-prose .wp-caption-text{
  color: var(--kc-slate-500);
  font-size: .92rem;
  margin: .5rem 0 1rem;
}

/* Prevent accidental horizontal scroll from wide blocks */
.kc-article{overflow-x: hidden;}

/* ===============================
   Related posts (with image)
   =============================== */
.kc-card--related .kc-card__link{display:block;}
.kc-card--related .kc-card__cover{border-radius:16px; overflow:hidden; aspect-ratio: 3/2; background:linear-gradient(135deg, rgba(17,141,201,.12), rgba(249,178,22,.12));}
.kc-card--related .kc-card__cover img{width:100%; height:100%; object-fit:cover;}
.kc-card--related .kc-card__body{padding-top:12px;}

/* ===============================
   Share icons
   =============================== */
.kc-share{margin: 32px;}
.kc-sharebar{display:flex; gap:10px; flex-wrap:wrap; align-items:center;}
.kc-sharebtn{
  width:42px; height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--kc-line);
  background:rgba(255,255,255,.6);
  border-radius:14px;
  transition:transform .12s ease, background .12s ease, border-color .12s ease;
  cursor:pointer;
}
.kc-sharebtn:hover{transform:translateY(-1px); background:#fff; border-color:rgba(17,141,201,.25);}
.kc-sharebtn:active{transform:translateY(0);} 
.kc-sharebtn__ic{display:inline-flex; color:var(--kc-ink);} 
.kc-sharehint{margin-top:10px; color:var(--kc-slate-500); font-size:.95rem;}

/* ===============================
   Comments
   =============================== */
#comments{margin-top:28px; padding-top:18px; border-top:1px solid var(--kc-line);}
.kc-comments__title{margin:0 0 10px;}
.comment-list{list-style:none; padding:0; margin:0 0 18px;}
.comment-body{border:1px solid var(--kc-line); border-radius:16px; padding:14px 14px; background:rgba(255,255,255,.5);}
.comment-meta{font-size:.92rem; color:var(--kc-slate-500); margin-bottom:8px;}
.comment-author .fn{font-weight:700; color:var(--kc-ink);} 
.comment-content p{margin:.6rem 0;}
.comment-respond{margin-top:18px;}
.kc-commentform .comment-form-comment textarea{width:100%; min-height:120px; border-radius:14px; border:1px solid var(--kc-line); padding:12px 12px; font:inherit;}
.kc-commentform input[type="text"],
.kc-commentform input[type="email"],
.kc-commentform input[type="number"]{width:100%; border-radius:14px; border:1px solid var(--kc-line); padding:10px 12px; font:inherit;}
.kc-commentform .form-submit input[type="submit"]{border-radius:14px; padding:10px 14px; border:1px solid rgba(17,141,201,.25); background:rgba(17,141,201,.1); cursor:pointer;}
.kc-commentform .form-submit input[type="submit"]:hover{background:rgba(17,141,201,.16);} 
.kc-comment-captcha{display:flex; gap:12px; align-items:flex-end; flex-wrap:wrap; margin-top:12px;}
.kc-comment-captcha .kc-captcha__hint{font-size:.9rem; color:var(--kc-slate-500);} 
.kc-comment-hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden;}

.kc-article .kc-prose{ max-width: 100%; }

.kc-pfMetric{
  border:1px solid var(--kc-line);
  border-radius:var(--kc-r-card);
  background:#fff;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  will-change: transform;
}

.kc-pfMetric:hover,
.kc-pfMetric:focus-within{
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(15,23,42,.08);
  border-color: color-mix(in srgb, var(--kc-accent, #f9b216) 35%, var(--kc-line));
}

.kc-pfChip{
  border:1px solid var(--kc-line);
  background:#fff;
  transition: background-color .18s ease, border-color .18s ease, transform .18s ease;
}

.kc-pfChip:hover{
  background: color-mix(in srgb, var(--kc-accent, #f9b216) 10%, #fff);
  border-color: color-mix(in srgb, var(--kc-accent, #f9b216) 35%, var(--kc-line));
  transform: translateY(-1px);
}

.kc-pfDetailGrid > *{
  border:1px solid var(--kc-line);
  border-radius:var(--kc-r-card);
  background:#fff;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.kc-pfDetailGrid > *:hover,
.kc-pfDetailGrid > *:focus-within{
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(15,23,42,.08);
  border-color: color-mix(in srgb, var(--kc-accent, #f9b216) 30%, var(--kc-line));
}

@media (prefers-reduced-motion: reduce){
  .kc-pfMetric,
  .kc-pfChip,
  .kc-pfDetailGrid > *{
    transition: none !important;
    transform: none !important;
  }
}

.kc-pfCard{
  border:1px solid var(--kc-line);
  border-radius: var(--kc-r-card);
  overflow:hidden;
  background:#fff;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.kc-pfCard:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 50px rgba(0,0,0,.10);
  border-color: color-mix(in oklab, var(--kc-line), #000 10%);
}

.kc-pfCard__cover{
  display:block;
  position:relative;
  background: #f6f7f9;
  aspect-ratio: 16 / 9; /* bikin cover konsisten */
  overflow:hidden;
}

.kc-pfCard__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform: scale(1.001);
  transition: transform .25s ease;
}

.kc-pfCard:hover .kc-pfCard__img{
  transform: scale(1.04);
}

.kc-pfCard__ph{
  position:absolute;
  inset:0;
  background: linear-gradient(120deg, #f2f3f5 0%, #fbfbfc 40%, #f2f3f5 100%);
  background-size: 220% 220%;
  animation: kcShimmer 1.6s ease infinite;
}

@keyframes kcShimmer{
  0%{ background-position: 0% 50% }
  100%{ background-position: 100% 50% }
}

.kc-pfCard__body{ padding:16px 16px 14px; }

.kc-pfCard__meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
}

.kc-pfTag{
  font-size:12px;
  line-height:1;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid var(--kc-line);
  background:#fff;
}

.kc-pfTag--year{
  background: color-mix(in oklab, #fff, var(--kc-accent, #f9b216) 12%);
  border-color: color-mix(in oklab, var(--kc-line), var(--kc-accent, #f9b216) 22%);
}

.kc-pfCard__title{
  margin:0 0 6px;
  font-size:18px;
  line-height:1.25;
  letter-spacing:-.2px;
}

.kc-pfCard__title a{
  color: inherit;
  text-decoration:none;
}

.kc-pfCard__client{
  margin:0 0 10px;
  font-size:13px;
  color: color-mix(in oklab, #000, #fff 45%);
}

.kc-pfCard__desc{
  margin:0 0 14px;
  color: color-mix(in oklab, #000, #fff 35%);
  display:-webkit-box;
  -webkit-line-clamp: 3;   /* biar tinggi card seragam */
  -webkit-box-orient: vertical;
  overflow:hidden;
  min-height: calc(1.45em * 3);
  line-height:1.45;
}

.kc-pfCard__cta{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:600;
  color: var(--kc-accent, #f9b216);
}

.kc-pfCard:hover .kc-pfCard__ctaArrow{
  transform: translateX(4px);
}

.kc-pfCard__ctaArrow{
  transition: transform .18s ease;
}
/* Portfolio Grid */
.kc-pfGrid{
  --pf-gap: 18px;
  display:grid;
  grid-template-columns: 1fr;
  gap: var(--pf-gap);
  align-items: stretch;
}

/* Tablet: 2 kolom */
@media (min-width: 640px){
  .kc-pfGrid{
    --pf-gap: 20px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Desktop: 3 kolom */
@media (min-width: 992px){
  .kc-pfGrid{
    --pf-gap: 22px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Wide desktop: 4 kolom */
@media (min-width: 1280px){
  .kc-pfGrid{
    --pf-gap: 24px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* Biar tinggi card konsisten */
.kc-pfGrid .kc-pfCard{
  height: 100%;
  display:flex;
  flex-direction: column;
}

/* body ngisi sisa tinggi */
.kc-pfGrid .kc-pfCard__body{
  flex: 1 1 auto;
  display:flex;
  flex-direction: column;
}

/* CTA selalu di bawah */
.kc-pfGrid .kc-pfCard__cta{
  margin-top: auto;
}

/* Clamp judul biar rapi */
.kc-pfGrid .kc-pfCard__title{
  display:-webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}

/* Clamp desc biar stabil */
.kc-pfGrid .kc-pfCard__desc{
  display:-webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:hidden;
  min-height: calc(1.45em * 3);
}