  :root {
      --bg: #0a0a0a;
      --bg-darker: #050505;
      --bg-card: #141414;
      --bg-card-hover: #1a1a1a;
      --fg: #f5f5f5;
      --fg-dim: #c0c0c0;
      --muted: #6a6a6a;
      --accent: #FF5400;
      --accent-bright: #FF7A33;
      --accent-dim: #B33A00;
      --accent-glow: rgba(255, 84, 0, 0.45);
      --silver: #C8C8C8;
      --silver-dim: #5a5a5a;
      --border: #1f1f1f;
      --border-light: #2a2a2a;
  }

  * {
      box-sizing: border-box;
  }

  html {
      scroll-behavior: smooth;
  }

  body {
      background: var(--bg);
      color: var(--fg);
      font-family: 'Archivo', sans-serif;
      overflow-x: hidden;
      margin: 0;
      -webkit-font-smoothing: antialiased;
  }

  /* Typography */
  .font-display {
      font-family: 'Bebas Neue', sans-serif;
      letter-spacing: 0.005em;
  }

  .font-heading {
      font-family: 'Oswald', sans-serif;
  }

  .font-body {
      font-family: 'Archivo', sans-serif;
  }

  .font-mono {
      font-family: 'JetBrains Mono', monospace;
  }

  /* Grain overlay */
  .grain {
      position: fixed;
      inset: -10%;
      pointer-events: none;
      z-index: 200;
      opacity: 0.08;
      background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='250' height='250'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
      mix-blend-mode: overlay;
      will-change: transform;
  }

  /* Section reveal */
  .reveal {
      opacity: 0;
      transform: translateY(48px);
      transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1), transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
      transition-delay: var(--delay, 0s);
  }

  .reveal.in-view {
      opacity: 1;
      transform: translateY(0);
  }

  .reveal-stagger>* {
      opacity: 0;
      transform: translateY(30px);
      transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1), transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .reveal-stagger.in-view>* {
      opacity: 1;
      transform: translateY(0);
  }

  .reveal-stagger.in-view>*:nth-child(1) {
      transition-delay: 0s;
  }

  .reveal-stagger.in-view>*:nth-child(2) {
      transition-delay: 0.1s;
  }

  .reveal-stagger.in-view>*:nth-child(3) {
      transition-delay: 0.2s;
  }

  .reveal-stagger.in-view>*:nth-child(4) {
      transition-delay: 0.3s;
  }

  .reveal-stagger.in-view>*:nth-child(5) {
      transition-delay: 0.4s;
  }

  .reveal-stagger.in-view>*:nth-child(6) {
      transition-delay: 0.5s;
  }

  /* Hero reel */
  .reel-frame {
      position: absolute;
      inset: 0;
      opacity: 0;
      transition: opacity 2s ease-in-out;
  }

  .reel-frame.active {
      opacity: 1;
  }

  .reel-frame img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: grayscale(100%) contrast(1.55) brightness(0.42);
      transform: scale(1.06);
  }

  .reel-frame.active img {
      animation: kenburns 9s ease-out forwards;
  }

  @keyframes kenburns {
      0% {
          transform: scale(1.06) translate(0, 0);
      }

      100% {
          transform: scale(1.2) translate(-3%, -3%);
      }
  }

  .hero-overlay {
      position: absolute;
      inset: 0;
      background:
          linear-gradient(180deg, rgba(10, 10, 10, 0.92) 0%, rgba(10, 10, 10, 0.45) 28%, rgba(10, 10, 10, 0.55) 65%, rgba(10, 10, 10, 0.98) 100%),
          linear-gradient(90deg, rgba(10, 10, 10, 0.85) 0%, rgba(10, 10, 10, 0.2) 50%, rgba(10, 10, 10, 0.5) 100%),
          radial-gradient(ellipse at 25% 60%, rgba(255, 84, 0, 0.18) 0%, transparent 55%);
  }

  /* Coach flip card */
  .flip-card {
      perspective: 1800px;
      height: 580px;
  }

  .flip-card-inner {
      position: relative;
      width: 100%;
      height: 100%;
      transition: transform 0.9s cubic-bezier(0.4, 0.2, 0.2, 1);
      transform-style: preserve-3d;
  }

  .flip-card:hover .flip-card-inner,
  .flip-card.flipped .flip-card-inner {
      transform: rotateY(180deg);
  }

  .flip-face {
      position: absolute;
      inset: 0;
      backface-visibility: hidden;
      -webkit-backface-visibility: hidden;
      overflow: hidden;
  }

  .flip-back {
      transform: rotateY(180deg);
  }

  /* Pulse */
  @keyframes pulse-cta {

      0%,
      100% {
          box-shadow: 0 0 0 0 rgba(255, 84, 0, 0.65), 0 0 40px rgba(255, 84, 0, 0.3);
      }

      50% {
          box-shadow: 0 0 0 18px rgba(255, 84, 0, 0), 0 0 40px rgba(255, 84, 0, 0.3);
      }
  }

  .pulse-btn {
      animation: pulse-cta 2.4s ease-out infinite;
  }

  /* Sticky bar */
  .sticky-cta {
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      transform: translateY(110%);
      transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
      z-index: 90;
  }

  .sticky-cta.visible {
      transform: translateY(0);
  }

  /* Marquee */
  @keyframes marquee {
      0% {
          transform: translateX(0);
      }

      100% {
          transform: translateX(-50%);
      }
  }

  .marquee-track {
      display: flex;
      animation: marquee 38s linear infinite;
      width: max-content;
  }

  /* Carousel */
  .story-track {
      display: flex;
      gap: 1.5rem;
      cursor: grab;
      user-select: none;
      will-change: transform;
      padding: 0 2rem;
  }

  .story-track.dragging {
      cursor: grabbing;
  }

  .story-track * {
      pointer-events: none;
  }

  /* Re-enable interactive elements inside story-track cards */
  .story-track button,
  .story-track a,
  .story-track .btn-preview,
  .story-track [data-pdf-close] {
      pointer-events: auto;
  }

  .story-card {
      flex: 0 0 auto;
      width: 400px;
      background: var(--bg-card);
      border: 1px solid var(--border);
      transition: border-color 0.4s, transform 0.4s;
  }

  .story-card:hover {
      border-color: var(--accent);
  }

  /* Image treatments */
  .img-noir {
      filter: grayscale(100%) contrast(1.4) brightness(0.7);
      transition: filter 0.8s ease, transform 0.8s ease;
  }

  /* Text effects */
  .text-stroke {
      -webkit-text-stroke: 1.5px var(--silver-dim);
      color: transparent;
  }

  .text-stroke-accent {
      -webkit-text-stroke: 1.5px var(--accent);
      color: transparent;
  }

  /* Vertical text */
  .vertical-text {
      writing-mode: vertical-rl;
      text-orientation: mixed;
  }

  /* Underline animation */
  .link-underline {
      position: relative;
      display: inline-block;
  }

  .link-underline::after {
      content: '';
      position: absolute;
      left: 0;
      bottom: -3px;
      width: 0;
      height: 1px;
      background: var(--accent);
      transition: width 0.4s ease;
  }

  .link-underline:hover::after {
      width: 100%;
  }

  /* Number counter */
  .number-display {
      font-variant-numeric: tabular-nums;
  }

  /* Input styles */
  .form-input {
      background: transparent;
      border: none;
      border-bottom: 1px solid var(--border-light);
      color: var(--fg);
      padding: 0.85rem 0;
      font-family: 'Oswald', sans-serif;
      font-size: 1.15rem;
      width: 100%;
      transition: border-color 0.3s;
      letter-spacing: 0.04em;
  }

  .form-input:focus {
      outline: none;
      border-color: var(--accent);
  }

  .form-input::placeholder {
      color: var(--muted);
      text-transform: uppercase;
      letter-spacing: 0.15em;
      font-size: 0.85rem;
  }

  /* Goal selector */
  .goal-pill {
      cursor: pointer;
      padding: 0.55rem 1.1rem;
      border: 1px solid var(--border-light);
      background: transparent;
      color: var(--fg-dim);
      font-family: 'Oswald', sans-serif;
      font-size: 0.85rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      transition: all 0.3s;
  }

  .goal-pill:hover {
      border-color: var(--silver-dim);
      color: var(--fg);
  }

  .goal-pill.active {
      background: var(--accent);
      border-color: var(--accent);
      color: #000;
      font-weight: 600;
  }

  /* Sound bars animation */
  @keyframes wave {

      0%,
      100% {
          height: 3px;
      }

      50% {
          height: 16px;
      }
  }

  .wave-bar {
      display: inline-block;
      width: 2px;
      background: var(--accent);
      margin: 0 1.5px;
      height: 3px;
      vertical-align: bottom;
  }

  .unmuted .wave-bar {
      animation: wave 0.7s ease-in-out infinite;
  }

  .wave-bar:nth-child(2) {
      animation-delay: 0.1s;
  }

  .wave-bar:nth-child(3) {
      animation-delay: 0.2s;
  }

  .wave-bar:nth-child(4) {
      animation-delay: 0.3s;
  }

  .wave-bar:nth-child(5) {
      animation-delay: 0.4s;
  }

  /* Program card hover */
  .program-card {
      transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .program-card:hover {
      transform: translateY(-8px);
  }

  .program-card .program-img {
      transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1), filter 0.8s;
  }

  .program-card:hover .program-img {
      transform: scale(1.08);
      filter: grayscale(80%) contrast(1.4) brightness(0.7);
  }

  .program-card:hover .program-number {
      color: var(--accent);
      -webkit-text-stroke-color: var(--accent);
  }

  /* Corner notch decoration */
  .notch-corner {
      position: relative;
  }

  .notch-corner::before,
  .notch-corner::after {
      content: '';
      position: absolute;
      width: 14px;
      height: 14px;
      border: 1px solid var(--accent);
      pointer-events: none;
  }

  .notch-corner::before {
      top: -1px;
      left: -1px;
      border-right: none;
      border-bottom: none;
  }

  .notch-corner::after {
      bottom: -1px;
      right: -1px;
      border-left: none;
      border-top: none;
  }

  /* Rec indicator */
  @keyframes rec-blink {

      0%,
      100% {
          opacity: 1;
      }

      50% {
          opacity: 0.3;
      }
  }

  .rec-dot {
      animation: rec-blink 1.5s ease-in-out infinite;
  }

  /* Custom scrollbar */
  ::-webkit-scrollbar {
      width: 8px;
      height: 8px;
  }

  ::-webkit-scrollbar-track {
      background: var(--bg-darker);
  }

  ::-webkit-scrollbar-thumb {
      background: var(--accent-dim);
  }

  ::-webkit-scrollbar-thumb:hover {
      background: var(--accent);
  }

  /* Toast */
  .toast {
      position: fixed;
      top: 90px;
      right: 24px;
      background: var(--bg-card);
      border: 1px solid var(--accent);
      border-left: 3px solid var(--accent);
      padding: 1rem 1.5rem;
      z-index: 150;
      transform: translateX(120%);
      transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
      max-width: 360px;
  }

  .toast.visible {
      transform: translateX(0);
  }

  /* Headline chars reveal */
  .headline-line {
      overflow: hidden;
      display: block;
  }

  .headline-line span {
      display: inline-block;
      transform: translateY(110%);
      transition: transform 1s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .in-view .headline-line span {
      transform: translateY(0);
  }

  .headline-line:nth-child(2) span {
      transition-delay: 0.1s;
  }

  .headline-line:nth-child(3) span {
      transition-delay: 0.2s;
  }

  /* Section divider */
  .section-marker {
      display: inline-flex;
      align-items: center;
      gap: 0.75rem;
      font-family: 'JetBrains Mono', monospace;
      font-size: 0.75rem;
      letter-spacing: 0.2em;
      color: var(--accent);
      text-transform: uppercase;
  }

  .section-marker::before {
      content: '';
      width: 32px;
      height: 1px;
      background: var(--accent);
  }

  /* Coach image overlay */
  .coach-img-wrap {
      position: relative;
      height: 70%;
      overflow: hidden;
  }

  .coach-img-wrap img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: grayscale(100%) contrast(1.35) brightness(0.78);
      transition: filter 0.6s, transform 0.8s;
  }

  .flip-card:hover .coach-img-wrap img,
  .flip-card.flipped .coach-img-wrap img {
      filter: grayscale(70%) contrast(1.4) brightness(0.85);
  }

  /* Booking panel */
  .booking-frame {
      background: linear-gradient(135deg, rgba(255, 84, 0, 0.04) 0%, transparent 50%, rgba(255, 84, 0, 0.02) 100%);
      border: 1px solid var(--border);
      position: relative;
  }

  .booking-frame::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 60px;
      height: 60px;
      border-top: 2px solid var(--accent);
      border-left: 2px solid var(--accent);
  }

  .booking-frame::after {
      content: '';
      position: absolute;
      bottom: 0;
      right: 0;
      width: 60px;
      height: 60px;
      border-bottom: 2px solid var(--accent);
      border-right: 2px solid var(--accent);
  }

  /* Subtle scan line */
  .scan-line {
      position: absolute;
      inset: 0;
      background: repeating-linear-gradient(0deg,
              transparent 0px,
              transparent 3px,
              rgba(0, 0, 0, 0.15) 3px,
              rgba(0, 0, 0, 0.15) 4px);
      pointer-events: none;
      z-index: 2;
  }

  /* Background texture */
  .bg-textured {
      background-color: var(--bg);
      background-image:
          radial-gradient(circle at 20% 30%, rgba(255, 84, 0, 0.06) 0%, transparent 40%),
          radial-gradient(circle at 80% 70%, rgba(80, 80, 80, 0.06) 0%, transparent 40%),
          url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='r'><feTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23r)' opacity='0.4'/></svg>");
      background-blend-mode: normal, normal, overlay;
  }

  /* Card hover light */
  .info-card {
      background: var(--bg-card);
      border: 1px solid var(--border);
      transition: border-color 0.4s, background 0.4s;
  }

  .info-card:hover {
      border-color: var(--accent-dim);
      background: var(--bg-card-hover);
  }

  /* Progress bar for hero */
  .progress-bar {
      height: 1px;
      background: rgba(255, 255, 255, 0.1);
      overflow: hidden;
  }

  .progress-bar-fill {
      height: 100%;
      background: var(--accent);
      width: 0%;
      transition: width 0.1s linear;
  }

  /* Nav link */
  .nav-link {
      position: relative;
      font-family: 'Oswald', sans-serif;
      font-size: 0.85rem;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--fg-dim);
      transition: color 0.3s;
  }

  .nav-link:hover {
      color: var(--fg);
  }

  .nav-link::before {
      content: '';
      position: absolute;
      left: -14px;
      top: 50%;
      transform: translateY(-50%) scaleY(0);
      width: 4px;
      height: 4px;
      background: var(--accent);
      transition: transform 0.3s;
  }

  .nav-link:hover::before {
      transform: translateY(-50%) scaleY(1);
  }

  /* ============================================
     LEAFLET MAP — LOKASI PPL
     ============================================ */

  .map-frame {
      position: relative;
      background: var(--bg-card);
      border: 1px solid var(--border);
      overflow: hidden;
      box-shadow: 0 20px 50px -20px rgba(0, 0, 0, 0.7);
  }

  .map-frame::before {
      content: '';
      position: absolute;
      top: -1px;
      left: -1px;
      width: 24px;
      height: 24px;
      border-top: 2px solid var(--accent);
      border-left: 2px solid var(--accent);
      z-index: 5;
      pointer-events: none;
  }

  .map-frame::after {
      content: '';
      position: absolute;
      bottom: -1px;
      right: -1px;
      width: 24px;
      height: 24px;
      border-bottom: 2px solid var(--accent);
      border-right: 2px solid var(--accent);
      z-index: 5;
      pointer-events: none;
  }

  .lokasi-map {
      width: 100%;
      height: 540px;
      background: #0d0d0d;
      filter: grayscale(0.35) contrast(1.05);
      transition: filter 0.6s ease;
  }

  .lokasi-map:hover {
      filter: grayscale(0.15) contrast(1.1);
  }

  .map-overlay-top,
  .map-overlay-bottom {
      position: absolute;
      left: 0;
      right: 0;
      height: 60px;
      pointer-events: none;
      z-index: 3;
  }

  .map-overlay-top {
      top: 0;
      background: linear-gradient(180deg, rgba(10, 10, 10, 0.65) 0%, transparent 100%);
  }

  .map-overlay-bottom {
      bottom: 0;
      background: linear-gradient(0deg, rgba(10, 10, 10, 0.55) 0%, transparent 100%);
  }

  .map-legend {
      position: absolute;
      bottom: 14px;
      left: 14px;
      z-index: 4;
      background: rgba(10, 10, 10, 0.85);
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
      border: 1px solid var(--border-light);
      padding: 10px 14px;
      display: flex;
      flex-direction: column;
      gap: 6px;
  }

  .legend-dot {
      display: inline-block;
      width: 10px;
      height: 10px;
      border-radius: 50%;
      flex-shrink: 0;
      box-shadow: 0 0 8px currentColor;
  }

  .legend-dot-unp {
      background: var(--accent);
      color: var(--accent);
  }

  .legend-dot-sma {
      background: #4cc9f0;
      color: #4cc9f0;
  }

  /* Leaflet tile attribution dark theme */
  .leaflet-container {
      background: #0d0d0d !important;
      font-family: 'Oswald', sans-serif !important;
  }

  .leaflet-control-attribution {
      background: rgba(10, 10, 10, 0.7) !important;
      color: var(--muted) !important;
      font-size: 10px !important;
      padding: 2px 8px !important;
      border: 1px solid var(--border-light) !important;
  }

  .leaflet-control-attribution a {
      color: var(--accent) !important;
  }

  .leaflet-control-zoom a {
      background: var(--bg-card) !important;
      color: var(--fg) !important;
      border: 1px solid var(--border-light) !important;
      font-weight: 700 !important;
      transition: all 0.3s ease !important;
  }

  .leaflet-control-zoom a:hover {
      background: var(--accent) !important;
      color: #000 !important;
      border-color: var(--accent) !important;
  }

  .leaflet-bar {
      box-shadow: none !important;
      border: none !important;
  }

  /* Custom marker */
  .custom-marker {
      background: transparent;
      border: none;
  }

  .marker-pin {
      width: 36px;
      height: 36px;
      border-radius: 50% 50% 50% 0;
      background: var(--accent);
      position: absolute;
      transform: rotate(-45deg);
      left: 50%;
      top: 50%;
      margin: -18px 0 0 -18px;
      box-shadow: 0 4px 14px rgba(255, 84, 0, 0.55);
      border: 2px solid #000;
      transition: transform 0.3s ease;
  }

  .marker-pin::after {
      content: '';
      width: 12px;
      height: 12px;
      margin: 10px 0 0 10px;
      background: #000;
      position: absolute;
      border-radius: 50%;
  }

  .marker-pin.sma {
      background: #4cc9f0;
      box-shadow: 0 4px 14px rgba(76, 201, 240, 0.55);
  }

  .custom-marker:hover .marker-pin {
      transform: rotate(-45deg) scale(1.15);
  }

  .marker-pulse {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      position: absolute;
      left: 50%;
      top: 50%;
      margin: -18px 0 0 -18px;
      animation: marker-pulse 2s ease-out infinite;
      pointer-events: none;
  }

  @keyframes marker-pulse {
      0% {
          transform: scale(0.5);
          opacity: 0.8;
      }

      100% {
          transform: scale(2.5);
          opacity: 0;
      }
  }

  .marker-pulse.unp {
      background: rgba(255, 84, 0, 0.35);
  }

  .marker-pulse.sma {
      background: rgba(76, 201, 240, 0.35);
  }

  /* Leaflet popup */
  .leaflet-popup-content-wrapper {
      background: var(--bg-card) !important;
      color: var(--fg) !important;
      border: 1px solid var(--accent) !important;
      border-radius: 0 !important;
      box-shadow: 0 10px 30px rgba(0, 0, 0, 0.7) !important;
      padding: 0 !important;
  }

  .leaflet-popup-content {
      margin: 0 !important;
      padding: 14px 18px !important;
      font-family: 'Oswald', sans-serif !important;
      line-height: 1.4 !important;
      min-width: 200px;
  }

  .leaflet-popup-tip {
      background: var(--accent) !important;
      border: none !important;
      box-shadow: none !important;
  }

  .leaflet-popup-close-button {
      color: var(--muted) !important;
      font-size: 20px !important;
      padding: 6px 8px 0 0 !important;
  }

  .leaflet-popup-close-button:hover {
      color: var(--accent) !important;
  }

  .popup-title {
      font-family: 'Bebas Neue', sans-serif;
      font-size: 1.25rem;
      letter-spacing: 0.05em;
      color: var(--accent);
      margin-bottom: 4px;
  }

  .popup-sub {
      font-family: 'JetBrains Mono', monospace;
      font-size: 10px;
      letter-spacing: 0.15em;
      color: var(--muted);
      text-transform: uppercase;
      margin-bottom: 8px;
  }

  .popup-desc {
      font-size: 12px;
      color: var(--fg-dim);
      line-height: 1.5;
  }

  /* Leaflet polyline (route line) */
  .leaflet-interactive {
      transition: stroke-opacity 0.3s ease;
  }

  @media (max-width: 768px) {
      .flip-card {
          height: 480px;
      }

      .story-card {
          width: 300px;
      }

      .lokasi-map {
          height: 400px;
      }
  }

  @media (max-width: 480px) {
      .lokasi-map {
          height: 340px;
      }

      .map-legend {
          bottom: 10px;
          left: 10px;
          padding: 8px 10px;
      }
  }

  /* ============================================
     PDF PREVIEW MODAL
     ============================================ */
  .pdf-modal {
      position: fixed;
      inset: 0;
      z-index: 300;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 1rem;
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.35s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.35s;
  }

  .pdf-modal[aria-hidden="false"] {
      opacity: 1;
      visibility: visible;
  }

  .pdf-modal-backdrop {
      position: absolute;
      inset: 0;
      background: rgba(0, 0, 0, 0.82);
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
      cursor: pointer;
  }

  .pdf-modal-container {
      position: relative;
      width: min(1100px, 100%);
      max-height: calc(100vh - 2rem);
      background: var(--bg-card);
      border: 1px solid var(--accent);
      box-shadow: 0 30px 80px rgba(0, 0, 0, 0.8), 0 0 60px rgba(255, 84, 0, 0.15);
      display: flex;
      flex-direction: column;
      transform: translateY(20px) scale(0.98);
      transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .pdf-modal[aria-hidden="false"] .pdf-modal-container {
      transform: translateY(0) scale(1);
  }

  .pdf-modal-container::before,
  .pdf-modal-container::after {
      content: '';
      position: absolute;
      width: 24px;
      height: 24px;
      border-color: var(--accent);
      border-style: solid;
      pointer-events: none;
  }

  .pdf-modal-container::before {
      top: -1px;
      left: -1px;
      border-width: 2px 0 0 2px;
  }

  .pdf-modal-container::after {
      bottom: -1px;
      right: -1px;
      border-width: 0 2px 2px 0;
  }

  .pdf-modal-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      padding: 1rem 1.25rem;
      border-bottom: 1px solid var(--border);
      background: linear-gradient(180deg, rgba(255, 84, 0, 0.06) 0%, transparent 100%);
      flex-shrink: 0;
  }

  .pdf-modal-body {
      flex: 1;
      min-height: 0;
      position: relative;
      background: #1a1a1a;
  }

  .pdf-modal-body iframe {
      width: 100%;
      height: 100%;
      min-height: 60vh;
      border: 0;
      display: block;
      background: #1a1a1a;
  }

  .pdf-fallback {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
      padding: 2rem;
  }

  .pdf-modal-footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
      padding: 0.65rem 1.25rem;
      border-top: 1px solid var(--border);
      background: rgba(0, 0, 0, 0.3);
      flex-shrink: 0;
  }

  .pdf-modal-footer kbd {
      font-family: 'JetBrains Mono', monospace;
      background: transparent;
  }

  body.pdf-modal-open {
      overflow: hidden;
  }

  /* ============================================
      REFLEKSI AKHIR & FILOSOFI MENGAJAR
      ============================================ */

  .question-card {
      position: relative;
      background: var(--bg-card);
      border: 1px solid var(--border);
      transition: border-color 0.4s, transform 0.4s, background 0.4s;
      overflow: hidden;
  }

  .question-card::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 4px;
      height: 100%;
      background: var(--accent);
      transition: width 0.4s;
  }

  .question-card:hover {
      border-color: var(--accent-dim);
      background: var(--bg-card-hover);
  }

  .question-card:hover::before {
      width: 8px;
  }

  .question-number {
      font-family: 'Bebas Neue', sans-serif;
      font-size: 4rem;
      line-height: 1;
      color: transparent;
      -webkit-text-stroke: 1.5px var(--accent);
      letter-spacing: 0.02em;
  }

  .question-icon {
      width: 56px;
      height: 56px;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--accent);
      color: #000;
      font-size: 1.4rem;
      flex-shrink: 0;
  }

  .answer-list {
      counter-reset: list-counter;
      list-style: none;
      padding: 0;
      margin: 0;
  }

  .answer-list>li {
      counter-increment: list-counter;
      position: relative;
      padding-left: 2.5rem;
      margin-bottom: 0.9rem;
      font-size: 0.875rem;
      line-height: 1.7;
      color: var(--fg-dim);
  }

  .answer-list>li::before {
      content: counter(list-counter, decimal-leading-zero);
      position: absolute;
      left: 0;
      top: 0.15rem;
      font-family: 'JetBrains Mono', monospace;
      font-size: 0.7rem;
      font-weight: 700;
      color: var(--accent);
      letter-spacing: 0.1em;
  }

  .answer-list>li strong {
      color: var(--fg);
      font-family: 'Oswald', sans-serif;
      font-weight: 500;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      font-size: 0.78rem;
      display: block;
      margin-bottom: 0.2rem;
  }

  /* Philosophy paragraph */
  .philosophy-paragraph {
      position: relative;
      padding: 1.75rem 0 1.75rem 5rem;
      border-top: 1px solid var(--border-light);
  }

  .philosophy-paragraph:first-child {
      border-top: none;
      padding-top: 0;
  }

  .philosophy-paragraph .p-marker {
      position: absolute;
      left: 0;
      top: 1.75rem;
      width: 3.5rem;
      height: 3.5rem;
      display: flex;
      align-items: center;
      justify-content: center;
      background: var(--bg-card);
      border: 1px solid var(--accent);
      font-family: 'Bebas Neue', sans-serif;
      font-size: 1.4rem;
      color: var(--accent);
      letter-spacing: 0.05em;
  }

  .philosophy-paragraph:first-child .p-marker {
      top: 0;
  }

  .philosophy-paragraph .p-heading {
      font-family: 'Oswald', sans-serif;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: var(--fg);
      font-size: 1.1rem;
      margin-bottom: 0.85rem;
  }

  .philosophy-paragraph .p-body {
      font-size: 0.95rem;
      line-height: 1.85;
      color: var(--fg-dim);
      margin-bottom: 1rem;
  }

  .philosophy-paragraph .p-body strong {
      color: var(--fg);
      font-weight: 600;
  }

  .philosophy-paragraph .p-reference {
      display: flex;
      align-items: flex-start;
      gap: 0.75rem;
      padding: 0.85rem 1rem;
      background: rgba(255, 84, 0, 0.04);
      border-left: 2px solid var(--accent);
      font-family: 'JetBrains Mono', monospace;
      font-size: 0.72rem;
      line-height: 1.6;
      color: var(--muted);
      letter-spacing: 0.05em;
  }

  .philosophy-paragraph .p-reference i {
      color: var(--accent);
      font-size: 0.7rem;
      margin-top: 0.2rem;
      flex-shrink: 0;
  }

  .philosophy-paragraph .p-reference .ref-label {
      color: var(--accent);
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.15em;
      margin-right: 0.5rem;
  }

  /* Section part divider */
  .part-divider {
      display: flex;
      align-items: center;
      gap: 1.25rem;
      margin: 0 0 2.5rem;
  }

  .part-divider .part-label {
      display: flex;
      align-items: center;
      gap: 0.65rem;
      font-family: 'JetBrains Mono', monospace;
      font-size: 0.7rem;
      letter-spacing: 0.25em;
      color: var(--accent);
      text-transform: uppercase;
      white-space: nowrap;
  }

  .part-divider .part-label::before {
      content: '';
      width: 28px;
      height: 1px;
      background: var(--accent);
  }

  .part-divider .part-line {
      flex: 1;
      height: 1px;
      background: var(--border-light);
  }

  .part-divider .part-title {
      font-family: 'Bebas Neue', sans-serif;
      font-size: 1.5rem;
      letter-spacing: 0.05em;
      color: var(--fg);
      margin: 0;
  }

  /* Manifesto-like accent column */
  .quote-pull {
      font-family: 'Archivo', sans-serif;
      font-size: 1.05rem;
      line-height: 1.7;
      color: var(--fg);
      font-style: italic;
      border-left: 3px solid var(--accent);
      padding: 0.75rem 0 0.75rem 1.25rem;
      margin: 1.25rem 0;
  }

  @media (max-width: 768px) {
      .question-number {
          font-size: 3rem;
      }

      .philosophy-paragraph {
          padding-left: 3.5rem;
      }

      .philosophy-paragraph .p-marker {
          width: 2.5rem;
          height: 2.5rem;
          font-size: 1.1rem;
      }

      .part-divider .part-title {
          font-size: 1.15rem;
      }
  }

  /* ============================================
      GALLERY DOKUMENTASI KEGIATAN PPL
      ============================================ */

  .gallery-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
      gap: 1.5rem;
  }

  .gallery-item {
      position: relative;
      background: var(--bg-card);
      border: 1px solid var(--border);
      overflow: hidden;
      transition: border-color 0.4s, transform 0.4s;
  }

  .gallery-item:hover {
      border-color: var(--accent-dim);
      transform: translateY(-4px);
  }

  .gallery-img-wrap {
      position: relative;
      aspect-ratio: 4 / 3;
      overflow: hidden;
      background: #1a1a1a;
  }

  .gallery-img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      filter: grayscale(100%) contrast(1.35) brightness(0.78);
      transition: filter 0.6s, transform 0.8s;
      display: block;
  }

  .gallery-item:hover .gallery-img {
      filter: grayscale(60%) contrast(1.4) brightness(0.85);
      transform: scale(1.06);
  }

  .gallery-number {
      position: absolute;
      top: 0.85rem;
      right: 0.85rem;
      width: 2.5rem;
      height: 2.5rem;
      display: flex;
      align-items: center;
      justify-content: center;
      background: rgba(0, 0, 0, 0.7);
      backdrop-filter: blur(6px);
      -webkit-backdrop-filter: blur(6px);
      border: 1px solid var(--accent);
      font-family: 'Bebas Neue', sans-serif;
      font-size: 1rem;
      color: var(--accent);
      letter-spacing: 0.05em;
      z-index: 2;
  }

  .gallery-tag {
      position: absolute;
      top: 0.85rem;
      left: 0.85rem;
      padding: 0.35rem 0.7rem;
      background: var(--accent);
      font-family: 'JetBrains Mono', monospace;
      font-size: 0.65rem;
      color: #000;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      font-weight: 700;
      z-index: 2;
  }

  .gallery-info {
      padding: 1.1rem 1.25rem;
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 0.75rem;
      border-top: 1px solid var(--border-light);
  }

  .gallery-text {
      flex: 1;
      min-width: 0;
  }

  .gallery-title {
      font-family: 'Oswald', sans-serif;
      font-weight: 500;
      color: var(--fg);
      font-size: 0.95rem;
      line-height: 1.3;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      margin-bottom: 0.3rem;
  }

  .gallery-date {
      font-family: 'JetBrains Mono', monospace;
      font-size: 0.7rem;
      color: var(--muted);
      letter-spacing: 0.15em;
      text-transform: uppercase;
  }

  .gallery-icon {
      flex-shrink: 0;
      width: 2.25rem;
      height: 2.25rem;
      display: flex;
      align-items: center;
      justify-content: center;
      border: 1px solid var(--border-light);
      color: var(--muted);
      font-size: 0.7rem;
      transition: border-color 0.3s, color 0.3s, background 0.3s;
  }

  .gallery-item:hover .gallery-icon {
      border-color: var(--accent);
      color: var(--accent);
      background: rgba(255, 84, 0, 0.08);
  }

  .gallery-hint {
      margin-top: 2.5rem;
      padding: 1.25rem 1.5rem;
      border: 1px dashed var(--border-light);
      background: rgba(255, 84, 0, 0.02);
      display: flex;
      align-items: flex-start;
      gap: 1rem;
  }

  .gallery-hint-icon {
      flex-shrink: 0;
      width: 2.5rem;
      height: 2.5rem;
      display: flex;
      align-items: center;
      justify-content: center;
      border: 1px solid var(--accent);
      color: var(--accent);
      font-size: 0.95rem;
  }

  .gallery-hint-text {
      flex: 1;
  }

  .gallery-hint-text strong {
      display: block;
      font-family: 'Oswald', sans-serif;
      font-size: 0.85rem;
      font-weight: 500;
      color: var(--fg);
      text-transform: uppercase;
      letter-spacing: 0.12em;
      margin-bottom: 0.35rem;
  }

  .gallery-hint-text p {
      font-size: 0.8rem;
      color: var(--muted);
      line-height: 1.55;
      margin: 0;
  }

  .gallery-hint-text code {
      background: rgba(255, 84, 0, 0.08);
      color: var(--accent);
      padding: 0.1rem 0.4rem;
      font-family: 'JetBrains Mono', monospace;
      font-size: 0.72rem;
  }

  @media (max-width: 768px) {
      .gallery-grid {
          grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
          gap: 1rem;
      }
  }

  @media (max-width: 768px) {
      .pdf-modal {
          padding: 0.5rem;
      }

      .pdf-modal-header {
          padding: 0.75rem 1rem;
      }

      .pdf-modal-body iframe {
          min-height: 70vh;
      }

      .pdf-modal-footer {
          padding: 0.5rem 1rem;
          flex-direction: column;
          align-items: flex-start;
          gap: 0.35rem;
      }
  }