/* =====================================================
   VISI MISI SECTION — CLEAN RESPONSIVE CSS
   ===================================================== */

.visi-misi-section {
  --vm-navy-1: #020b24;
  --vm-navy-2: #061842;
  --vm-navy-3: #051433;
  --vm-gold: #d4af37;
  --vm-red: #ff3b3b;
  --vm-white: #fffaf0;
  --vm-muted: rgba(255, 250, 240, 0.78);
  --vm-border: rgba(255, 255, 255, 0.095);

  --vm-container: 1080px;
  --vm-section-y: clamp(72px, 7vw, 104px);
  --vm-gap: clamp(34px, 4vw, 48px);

  --vm-title-size: clamp(2.25rem, 4.1vw, 3.65rem);
  --vm-label-size: 0.76rem;
  --vm-label-spacing: 0.34em;

  --vm-header-bottom: 28px;
  --vm-card-padding: clamp(26px, 3vw, 34px);
  --vm-card-radius: 20px;
  --vm-card-gap: 18px;

  --vm-vision-size: clamp(1rem, 1.35vw, 1.22rem);
  --vm-body-size: 0.92rem;

  --vm-misi-gap: 14px;
  --vm-misi-y: 18px;
  --vm-misi-x: 20px;

  --vm-icon-size: 42px;
  --vm-icon-svg: 20px;
  --vm-icon-gap: 16px;

  position: relative;
  overflow: hidden;
  padding: var(--vm-section-y) 0;
  scroll-margin-top: 88px;
  background:
    radial-gradient(circle at 25% 30%, rgba(212, 175, 55, 0.07), transparent 28%),
    radial-gradient(circle at 75% 25%, rgba(211, 47, 47, 0.055), transparent 26%),
    linear-gradient(180deg, var(--vm-navy-1) 0%, var(--vm-navy-2) 45%, var(--vm-navy-3) 100%);
  color: var(--vm-white);
}

.visi-misi-section *,
.visi-misi-section *::before,
.visi-misi-section *::after {
  box-sizing: border-box;
}

.visi-misi-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255, 255, 255, 0.014) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.014) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(circle at center, black, transparent 72%);
  opacity: 0.28;
  pointer-events: none;
}

.visi-misi-section::after {
  content: "";
  position: absolute;
  top: 10%;
  left: 50%;
  width: min(520px, 68vw);
  height: min(520px, 68vw);
  transform: translateX(-50%);
  border: 1px solid rgba(212, 175, 55, 0.055);
  border-radius: 50%;
  pointer-events: none;
}

/* =====================================================
   Layout
   ===================================================== */

.visi-misi-container {
  position: relative;
  z-index: 1;
  width: min(calc(100% - 40px), var(--vm-container));
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(0, 0.98fr) minmax(0, 1fr);
  gap: var(--vm-gap);
  align-items: start;
}

.visi-section,
.misi-section {
  min-width: 0;
}

/* =====================================================
   Header
   ===================================================== */

.visi-header,
.misi-header {
  margin-bottom: var(--vm-header-bottom);
}

.visi-label,
.misi-label {
  margin: 0 0 14px;
  color: var(--vm-gold);
  font-family: var(--font-display, "Cinzel", Georgia, serif);
  font-size: var(--vm-label-size);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: var(--vm-label-spacing);
  text-transform: uppercase;
}

.visi-title,
.misi-title {
  margin: 0;
  color: var(--vm-white);
  font-family: var(--font-display, "Cinzel", Georgia, serif);
  font-size: var(--vm-title-size);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: 0.075em;
  text-transform: uppercase;
  text-shadow: 0 8px 28px rgba(0, 0, 0, 0.34);
}

.visi-header::after,
.misi-header::after {
  content: "";
  display: block;
  width: 64px;
  height: 1px;
  margin-top: 20px;
  background: linear-gradient(
    90deg,
    rgba(212, 175, 55, 0.95),
    transparent
  );
}

/* =====================================================
   Cards
   ===================================================== */

.visi-card {
  position: relative;
  padding: var(--vm-card-padding);
  border: 1px solid rgba(212, 175, 55, 0.24);
  border-radius: var(--vm-card-radius);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.014)),
    rgba(10, 26, 63, 0.72);
  box-shadow:
    0 18px 52px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
  overflow: hidden;
  transition:
    transform 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease;
}

.visi-card + .visi-card {
  margin-top: var(--vm-card-gap);
}

.visi-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(212, 175, 55, 0.09), transparent 35%);
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.visi-card-main .misi-icon {
  margin-bottom: 18px;
}

.visi-text {
  position: relative;
  z-index: 1;
  margin: 0;
  color: rgba(255, 245, 230, 0.94);
  font-family: var(--font-body, "Crimson Pro", Georgia, serif);
  font-size: var(--vm-vision-size);
  font-weight: 600;
  font-style: italic;
  line-height: 1.72;
}

.visi-slogan {
  border-color: rgba(211, 47, 47, 0.22);
  background:
    linear-gradient(180deg, rgba(58, 22, 82, 0.22), rgba(18, 16, 60, 0.12)),
    rgba(11, 20, 55, 0.74);
}

.visi-slogan::before {
  background: radial-gradient(circle at left center, rgba(211, 47, 47, 0.10), transparent 38%);
}

.visi-slogan .visi-label {
  margin-bottom: 18px;
  font-size: calc(var(--vm-label-size) - 0.04rem);
}

.slogan-text {
  position: relative;
  z-index: 1;
  margin: 0;
  color: var(--vm-muted);
  font-family: var(--font-body, "Crimson Pro", Georgia, serif);
  font-size: var(--vm-body-size);
  font-weight: 600;
  line-height: 1.75;
}

.slogan-gold {
  color: var(--vm-gold);
  font-weight: 700;
}

.slogan-muted {
  color: rgba(212, 175, 55, 0.76);
}

.slogan-red {
  color: var(--vm-red);
  font-weight: 700;
}

/* =====================================================
   Misi List
   ===================================================== */

.misi-list {
  display: grid;
  gap: var(--vm-misi-gap);
  margin: 0;
  padding: 0;
  list-style: none;
}

.misi-item {
  position: relative;
  min-width: 0;
  display: grid;
  grid-template-columns: var(--vm-icon-size) minmax(0, 1fr);
  gap: var(--vm-icon-gap);
  align-items: center;
  padding: var(--vm-misi-y) var(--vm-misi-x);
  border: 1px solid var(--vm-border);
  border-radius: 17px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.032), rgba(255, 255, 255, 0.012)),
    rgba(9, 23, 57, 0.72);
  box-shadow:
    0 14px 36px rgba(0, 0, 0, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  overflow: hidden;
  transition:
    transform 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease,
    background-color 0.35s ease;
}

.misi-item::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(212, 175, 55, 0.08), transparent 26%);
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.misi-item-featured {
  border-color: rgba(212, 175, 55, 0.28);
}

.misi-item p {
  position: relative;
  z-index: 1;
  margin: 0;
  color: rgba(255, 245, 230, 0.90);
  font-family: var(--font-body, "Crimson Pro", Georgia, serif);
  font-size: var(--vm-body-size);
  font-weight: 600;
  line-height: 1.62;
}

/* =====================================================
   Icon
   ===================================================== */

.misi-icon {
  position: relative;
  z-index: 1;
  width: var(--vm-icon-size);
  height: var(--vm-icon-size);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--vm-gold);
  background: rgba(26, 55, 130, 0.75);
  border-radius: 12px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 10px 22px rgba(0, 0, 0, 0.16);
  transition:
    transform 0.35s ease,
    box-shadow 0.35s ease;
}

.misi-icon svg {
  width: var(--vm-icon-svg);
  height: var(--vm-icon-svg);
  stroke: currentColor;
  stroke-width: 1.9;
}

/* =====================================================
   Hover
   ===================================================== */

@media (hover: hover) and (pointer: fine) {
  .visi-card:hover,
  .misi-item:hover {
    transform: translateY(-4px);
    border-color: rgba(212, 175, 55, 0.38);
    box-shadow:
      0 22px 58px rgba(0, 0, 0, 0.28),
      0 0 24px rgba(212, 175, 55, 0.07);
  }

  .visi-card:hover::before,
  .misi-item:hover::before {
    opacity: 1;
  }

  .misi-item:hover .misi-icon,
  .visi-card:hover .misi-icon {
    transform: translateY(-1px);
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.08),
      0 13px 26px rgba(0, 0, 0, 0.22);
  }
}

/* =====================================================
   Laptop kecil / 1366px
   ===================================================== */

@media (max-width: 1366px) {
  .visi-misi-section {
    --vm-container: 1000px;
    --vm-section-y: 74px;
    --vm-gap: 36px;

    --vm-title-size: clamp(2.05rem, 3.35vw, 3.05rem);
    --vm-label-size: 0.68rem;
    --vm-label-spacing: 0.30em;

    --vm-header-bottom: 24px;
    --vm-card-padding: 28px;
    --vm-card-radius: 18px;
    --vm-card-gap: 16px;

    --vm-vision-size: 1.06rem;
    --vm-body-size: 0.86rem;

    --vm-misi-gap: 13px;
    --vm-misi-y: 16px;
    --vm-misi-x: 18px;

    --vm-icon-size: 38px;
    --vm-icon-svg: 18px;
    --vm-icon-gap: 14px;
  }

  .visi-label,
  .misi-label {
    margin-bottom: 12px;
  }

  .visi-header::after,
  .misi-header::after {
    margin-top: 18px;
  }

  .visi-text {
    line-height: 1.66;
  }

  .misi-item p {
    line-height: 1.58;
  }
}

/* Laptop pendek, contoh 1366 x 768 */
@media (min-width: 1025px) and (max-height: 780px) {
  .visi-misi-section {
    --vm-section-y: 58px;
    --vm-gap: 32px;
    --vm-title-size: clamp(2rem, 3vw, 2.75rem);
    --vm-header-bottom: 20px;
    --vm-card-padding: 24px;
    --vm-card-gap: 14px;
    --vm-vision-size: 1rem;
    --vm-body-size: 0.82rem;
    --vm-misi-gap: 12px;
    --vm-misi-y: 14px;
    --vm-misi-x: 16px;
    --vm-icon-size: 36px;
    --vm-icon-svg: 17px;
  }

  .visi-header::after,
  .misi-header::after {
    width: 56px;
    margin-top: 16px;
  }

  .visi-card-main .misi-icon {
    margin-bottom: 14px;
  }

  .slogan-text {
    line-height: 1.62;
  }

  .misi-item {
    border-radius: 15px;
  }
}

/* Tablet landscape / laptop kecil dengan zoom browser */
@media (max-width: 1120px) {
  .visi-misi-section {
    --vm-container: 680px;
    --vm-section-y: 72px;
    --vm-gap: 42px;
    --vm-title-size: clamp(2rem, 5vw, 3rem);
  }

  .visi-misi-container {
    grid-template-columns: 1fr;
  }
}

/* Mobile */
@media (max-width: 640px) {
  .visi-misi-section {
    --vm-section-y: 66px;
    --vm-title-size: clamp(1.8rem, 9.2vw, 2.55rem);
    --vm-label-size: 0.66rem;
    --vm-label-spacing: 0.24em;
    --vm-card-padding: 22px;
    --vm-vision-size: 0.96rem;
    --vm-body-size: 0.86rem;
    --vm-misi-y: 15px;
    --vm-misi-x: 14px;
    --vm-icon-size: 38px;
    --vm-icon-svg: 18px;
    --vm-icon-gap: 12px;
  }

  .visi-misi-container {
    width: min(calc(100% - 28px), var(--vm-container));
    gap: 34px;
  }

  .visi-title,
  .misi-title {
    letter-spacing: 0.055em;
  }

  .visi-card {
    border-radius: 16px;
  }

  .misi-item {
    grid-template-columns: var(--vm-icon-size) minmax(0, 1fr);
    border-radius: 15px;
  }
}

/* Small mobile */
@media (max-width: 390px) {
  .visi-misi-section {
    --vm-section-y: 58px;
    --vm-card-padding: 20px;
    --vm-title-size: clamp(1.65rem, 9vw, 2.25rem);
    --vm-vision-size: 0.92rem;
    --vm-body-size: 0.82rem;
  }

  .visi-misi-container {
    width: calc(100% - 24px);
  }
}

/* =====================================================
   Reveal Animation
   Content tetap tampil kalau JS gagal
   ===================================================== */

.visi-misi-section.has-js .vm-reveal,
.visi-misi-section.has-js .vm-reveal-scale {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.72s ease,
    transform 0.72s cubic-bezier(0.22, 1, 0.36, 1);
}

.visi-misi-section.has-js .vm-reveal-scale {
  transform: translateY(18px) scale(0.98);
}

.visi-misi-section.has-js .vm-reveal.is-visible,
.visi-misi-section.has-js .vm-reveal-scale.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.visi-misi-section.has-js .misi-item.vm-reveal:nth-child(1) {
  transition-delay: 0.04s;
}

.visi-misi-section.has-js .misi-item.vm-reveal:nth-child(2) {
  transition-delay: 0.10s;
}

.visi-misi-section.has-js .misi-item.vm-reveal:nth-child(3) {
  transition-delay: 0.16s;
}

.visi-misi-section.has-js .misi-item.vm-reveal:nth-child(4) {
  transition-delay: 0.22s;
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
  .visi-misi-section.has-js .vm-reveal,
  .visi-misi-section.has-js .vm-reveal-scale,
  .visi-card,
  .misi-item,
  .misi-icon,
  .visi-card::before,
  .misi-item::before {
    opacity: 1;
    transform: none;
    transition: none;
    animation: none;
  }
}