.hero-slider {
  position:relative;
  height:600px;               
  overflow:hidden;
}
.hero-slider__track {
  display:flex; height:100%; width:100%;
  transition:transform .7s cubic-bezier(.65,.05,.36,1);
  will-change:transform;
}
.hero-slide {
  position:relative;
  flex:0 0 100%; height:100%;
  display:flex; align-items:center;
}
.hero-slide .hero__bg { position:absolute; inset:0; z-index:0; }
.hero-slide .hero__img { width:100%; height:100%; object-fit:cover; }
.hero-slide .hero__overlay {
  position:absolute; inset:0;
  background:transparent;
}
.hero-slide .hero__overlay {
  background:linear-gradient(
    90deg,
    rgba(11,45,108,.55) 0%,
    rgba(11,45,108,.35) 38%,
    rgba(11,45,108,.10) 60%,
    rgba(11,45,108,0)   100%
  );
}

.hero__inner {
  position:relative; z-index: 2;
  width:100%;
}
.hero-slide .hero__content {
  max-width:1440px;
  text-align:left;
}
.hero__title {
  color:var(--white);
  font-size:clamp(2rem,4.5vw,3.4rem);
  font-weight:800; line-height:1.12;
  letter-spacing: -0.02em; text-transform:uppercase;
  margin: 50 0 0 10px;
  text-shadow:0 2px 12px #00000059;
}
.hero__accent { color:var(--gold); }       
.hero__tagline {
  color:rgba(255,255,255,.92);
  font-size:clamp(1rem,1.6vw,1.15rem);
  line-height:1.6; margin-bottom:30px;
  max-width:520px;
}
.hero__actions {
  display:flex; gap:14px; flex-wrap:wrap;
  justify-content:flex-start;   
}

.hero-slider__arrow {
  position:absolute; top:50%; transform:translateY(-50%);
  z-index:5; width:48px; height:48px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.4);
  color:var(--white); font-size:1.4rem; border-radius:50%;
  cursor:pointer; backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  transition:background .25s ease, transform .25s ease;
}
.hero-slider__arrow:hover { background:rgba(255,255,255,.3); }
.hero-slider__arrow--prev { left:24px; }
.hero-slider__arrow--next { right:24px; }
.hero-slider__arrow--prev:hover { transform:translateY(-50%) scale(1.08); }
.hero-slider__arrow--next:hover { transform:translateY(-50%) scale(1.08); }
.hero-slider__dots {
  position:absolute; left:0; right:0; bottom:26px; z-index:5;
  display:flex; justify-content:center; gap:10px;
}
.hero-slider__dot {
  width:11px; height:11px; border-radius:50%;
  background:rgba(255,255,255,.45); border:none; cursor:pointer; padding:0;
  transition:background .25s ease, transform .25s ease;
}
.hero-slider__dot:hover { background:rgba(255,255,255,.75); }
.hero-slider__dot.is-active { background:var(--white); transform:scale(1.25); }

@media (max-width:768px) {
  .hero-slider {height:520px;}
  .hero__title { font-size:1.6rem; line-height:1.15; }
  .hero__tagline { font-size:.9rem; margin-bottom:18px; }
  .hero__actions .btn { padding:10px 16px; font-size:.85rem; }
  .hero-slide .hero__content { max-width: 1440px; }
}

.btn--primary {
  background:linear-gradient(135deg, var(--blue-accent), var(--blue-hover));
  color:var(--white);
  box-shadow:0 4px 16px rgba(37,99,235,.35);
}
.btn--primary:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(37,99,235,.5);
  background:linear-gradient(135deg,#3b82f6,var(--blue-accent));
}
.btn--ghost {
  background:rgba(255,255,255,.12);
  color:var(--white);
  border:1px solid rgba(255,255,255,.4);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.btn--ghost:hover {
  background:rgba(255,255,255,.22);
  transform:translateY(-2px);
}

.sectors { padding:var(--section-pad) 0; background:var(--off-white); }
.sectors__grid {
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:18px;
}
.sector {
  position:relative; display:flex; align-items:flex-end; justify-content:center;
  height:150px; border-radius:var(--radius-md);
  overflow:hidden; box-shadow:var(--shadow-sm);
  transition:transform .3s ease, box-shadow .3s ease;
}
.sector:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.sector__bg {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease;
}
.sector:hover .sector__bg { transform:scale(1.08); }
.sector__shade {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(11,45,108,.82) 0%, rgba(11,45,108,.15) 70%);
}
.sector__label {
  position:relative; z-index:1;
  padding-bottom:16px;
  color:var(--white); font-size:.95rem; font-weight:700;
  letter-spacing:-.01em;
}

.story { padding:var(--section-pad) 0; background:#dfe6f1; }
.story__block {
  display:grid; grid-template-columns:1fr 1.1fr;
  gap:56px; align-items:center; margin-bottom:56px;
}
.story__block:last-child { margin-bottom:0; }
.story__block--reverse { direction:rtl; }
.story__block--reverse > * { direction:ltr; }
.story__image {
  border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-md); aspect-ratio:4/3;
}
.story__image img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease;
}
.story__image:hover img { transform:scale(1.04); }
.story__content h3 {
  font-size:clamp(1.3rem,2.5vw,1.8rem);
  color:var(--navy); font-weight:800; margin-bottom:14px;
}
.story__content p { font-size:.975rem; color:var(--text-body); line-height:1.8; }


.why { padding:var(--section-pad) 0; background:var(--white); }
.why__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.why__item {
  background:var(--off-white); border:1px solid var(--gray-100);
  border-radius:var(--radius-md); padding:32px 28px;
  text-align:center; box-shadow:var(--shadow-sm);
  transition:transform .25s ease, box-shadow .25s ease;
}
.why__item:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.why__icon {
  width:56px; height:56px; margin:0 auto 18px;
  display:flex; align-items:center; justify-content:center;
}
.why__icon img { width:100%; height:100%; object-fit:contain; }
.why__item h3 { font-size:1.05rem; font-weight:700; color:var(--navy); margin-bottom:8px; }
.why__item p { font-size:.875rem; color:var(--gray-700); line-height:1.55; }

.stats { padding:var(--section-pad) 0; background:var(--off-white); }
.stats__grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.stats__item {
  background:var(--white); border:1px solid var(--gray-100);
  border-radius:var(--radius-md); padding:28px 20px;
  text-align:center; box-shadow:var(--shadow-sm);
}
.stats__num {
  display:block;
  font-size:clamp(2rem,4vw,2.8rem); font-weight:800;
  color:var(--blue-accent); line-height:1;
  letter-spacing:-.03em; margin-bottom:10px;
}
.stats__label { display:block; font-size:.95rem; font-weight:700; color:var(--navy); margin-bottom:4px; }
.stats__desc { display:block; font-size:.78rem; color:var(--gray-500); line-height:1.4; }
.stats__foot { text-align:center; margin-top:28px; font-size:.875rem; color:var(--gray-500); }


.products { padding:var(--section-pad) 0; background:var(--white); }
.products__grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:22px;
}
.product-card {
  position:relative; display:flex; align-items:flex-end;
  height:300px; border-radius:var(--radius-md);
  overflow:hidden; box-shadow:var(--shadow-sm);
  transition:transform .3s ease, box-shadow .3s ease;
}
.product-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); }
.product-card__bg {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease;
}
.product-card:hover .product-card__bg { transform:scale(1.06); }
.product-card__shade {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(11,45,108,.5) 0%, transparent 55%);
}
.product-card__name {
  position:relative; z-index:1; width:100%;
  margin:14px; padding:14px 18px;
  background:var(--blue-accent); color:var(--white);
  font-size:1.05rem; font-weight:700;
  border-radius:var(--radius-sm);
  box-shadow:0 6px 18px rgba(37,99,235,.4);
  transition:background .25s ease;
}
.product-card:hover .product-card__name { background:var(--blue-hover); }

.partners {
  padding:36px 0;
  background:var(--white);
  border-top:1px solid var(--gray-100);
  border-bottom:1px solid var(--gray-100);
  overflow:hidden;
}
.partners__row { overflow:hidden; -webkit-mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent); mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent); }
.partners__track {
  display:flex; align-items:center; gap:72px;
  width:max-content;
  animation:marquee 32s linear infinite;
}
.partners__row:hover .partners__track { animation-play-state:paused; }
.partners__track img {
  height:42px; width:auto; object-fit:contain;
  opacity:.85; transition:opacity .25s;
}
.partners__track img:hover { opacity:1; }
@keyframes marquee {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

.inspirasi {
  padding:var(--section-pad) 0;
  background:linear-gradient(135deg, var(--blue-accent) 0%, var(--blue-hover) 100%);
}
.inspirasi__head {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:36px; gap:16px; flex-wrap:wrap;
}
.inspirasi__title {
  color:var(--white); font-size:clamp(1.4rem,2.5vw,2rem);
  font-weight:800; letter-spacing:-.02em;
}
.inspirasi__link {
  color:var(--white); font-size:.9rem; font-weight:600;
  padding:8px 18px; border-radius:99px;
  border:1px solid rgba(255,255,255,.5);
  transition:background .25s ease;
}
.inspirasi__link:hover { background:rgba(255,255,255,.15); }
.inspirasi__grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.inspirasi__card {
  position:relative; display:flex; align-items:flex-end;
  height:300px; border-radius:var(--radius-md);
  overflow:hidden; box-shadow:var(--shadow-md);
  background:rgba(255,255,255,.1);
  transition:transform .3s ease;
}
.inspirasi__card:hover { transform:translateY(-6px); }
.inspirasi__bg {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease;
}
.inspirasi__card:hover .inspirasi__bg { transform:scale(1.06); }
.inspirasi__shade {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(11,45,108,.88) 0%, transparent 65%);
}
.inspirasi__text { position:relative; z-index:1; padding:24px; }
.inspirasi__tag {
  display:inline-block; font-size:.7rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--white); background:rgba(37,99,235,.55);
  padding:4px 12px; border-radius:99px; margin-bottom:10px;
}
.inspirasi__text h3 { color:var(--white); font-size:1.05rem; font-weight:700; line-height:1.3; }


.footer__grid--home { grid-template-columns:1.6fr 1fr 1fr 1fr; }

@media (max-width:1024px) {
  .sectors__grid { grid-template-columns:repeat(3,1fr); }
  .products__grid { grid-template-columns:repeat(2,1fr); }
  .stats__grid { grid-template-columns:repeat(2,1fr); }
  .footer__grid--home { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  .hero--home { height:480px; }
  .help__grid { grid-template-columns:1fr; }
  .sectors__grid { grid-template-columns:repeat(2,1fr); }
  .story__block,
  .story__block--reverse { grid-template-columns:1fr; gap:28px; direction:ltr; }
  .why__grid { grid-template-columns:1fr; }
  .inspirasi__grid { grid-template-columns:1fr; }
  .footer__grid--home { grid-template-columns:1fr; }
  .partners__track { gap:48px; }
  .partners__track img { height:34px; }
}
@media (max-width:480px) {
  .hero__actions { flex-direction:column; width:100%; }
  .hero__actions .btn { width:100%; justify-content:center; }
  .sectors__grid { grid-template-columns:1fr 1fr; }
  .stats__grid { grid-template-columns:1fr 1fr; }
  .products__grid { grid-template-columns:1fr; }
}

a.gallery__card { text-decoration:none; color:inherit; display:block; }

.gallery__card--more {
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--navy), var(--navy-mid));
  color:var(--white);
}
.gallery__card--more:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.gallery__more {
  display:flex; flex-direction:column; align-items:center; gap:12px;
  text-align:center; padding:24px;
}
.gallery__more-arrow {
  width:52px; height:52px; border-radius:50%;
  border:2px solid var(--white); background:rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; line-height:1; color:var(--white);
  transition:background .25s ease, transform .25s ease;
}
.gallery__card--more:hover .gallery__more-arrow {
  background:rgba(255,255,255,.18); transform:translateX(4px);
}
.gallery__more-text {
  font-size:.92rem; font-weight:700; line-height:1.4; max-width:200px; color:var(--white);
}