/* Landing PJK3 — soft minimal (PJK3), aksen utama maroon */

:root {
    /* Brand — merah logo PLS (#881719) */
    --maroon: #881719;
    --maroon-dark: #6b1214;
    --maroon-soft: #fce9e9;
    --maroon-muted: #c97a7c;
    --maroon-rgb: 136, 23, 25;
    --green: #1c7a47;
    --green-dark: #155f37;
    --green-soft: #e8f5ee;
    --green-muted: #b8dcc8;
    --green-rgb: 28, 122, 71;

    /* UI */
    --ink: #2d3748;
    --ink-muted: #64748b;
    --border: #e8ece9;
    --border-soft: #f0f2f1;
    --surface: #f3f5f4;
    --surface-elevated: #ffffff;

    --pjk3-primary: var(--maroon);
    --pjk3-primary-hover: var(--maroon-dark);
    --pjk3-section-bg: #5a1012;
    --pjk3-gray-500: var(--ink-muted);
    --pjk3-max: 1280px;
    --pjk3-gutter-x: 1rem;
    --shadow-soft: 0 1px 2px rgba(45, 55, 72, 0.04), 0 4px 16px rgba(45, 55, 72, 0.04);
    --radius: 0.625rem;

    /* Tombol Selia — gradasi + highlight + edge */
    --btn-radius: 0.75rem;
    --btn-3d-y: 2px;
    --btn-3d-edge: #c5cad0;
    --btn-3d-edge-dark: #141414;
    --btn-highlight: rgba(255, 255, 255, 0.22);

    /* Jarak antar section — mengikuti pola section (py-16 / py-12 / py-20) */
    --section-y: 4rem;
    --section-y-md: 3rem;
    --section-dark-y: 4.5rem;
    --section-cta-y: 5rem;
    --section-head-gap: 2rem;

    --header-bg: rgba(255, 255, 255, 0.92);
    --hero-overlay: linear-gradient(135deg, rgba(255, 255, 255, 0.35) 0%, rgba(255, 255, 255, 0.55) 100%);
    --hero-fade-top: linear-gradient(180deg, #fff 0%, rgba(255, 255, 255, 0) 100%);
    --placeholder: #94a3b8;

    /* Motion — PJK3 (ease-out, tidak kaku) */
    --pjk3-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
    --pjk3-ease-soft: cubic-bezier(0.33, 1, 0.68, 1);
    --pjk3-duration-fast: 0.15s;
    --pjk3-duration: 0.28s;
    --pjk3-duration-slow: 0.55s;
    --pjk3-shadow-hover: 0 12px 28px rgba(45, 55, 72, 0.12);
    --pjk3-shadow-hover-lg: 0 16px 40px rgba(45, 55, 72, 0.16);

    /* Typography — Inter headings / nav, Plus Jakarta body */
    --pjk3-font-body: 'Plus Jakarta Sans', system-ui, sans-serif;
    --pjk3-font-heading: 'Inter', system-ui, sans-serif;
    --pjk3-tracking-heading: -0.04em;
    --pjk3-tracking-heading-lg: -0.045em;
    --pjk3-tracking-nav: -0.03em;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-padding-top: 80px;
}

@media (prefers-reduced-motion: no-preference) {
    html {
        scroll-behavior: smooth;
    }
}

body.pjk3-landing {
    font-family: var(--pjk3-font-body);
    color: var(--ink);
    background: var(--surface-elevated);
    -webkit-font-smoothing: antialiased;
}

/* Heading & site header — Inter, letter-spacing rapat */
.pjk3-header,
.pjk3-mobile-menu,
.pjk3-hero-title,
.pjk3-section-title,
.pjk3-section-title-light,
.pjk3-page-title,
.pjk3-flow-title,
.pjk3-contact-form-title,
.pjk3-footer-cta span,
.pjk3-landing h1,
.pjk3-landing h2,
.pjk3-landing h3,
.pjk3-eyebrow,
.pjk3-eyebrow-light {
    font-family: var(--pjk3-font-heading);
}

.pjk3-nav a,
.nav-link-dropdown,
.pjk3-mobile-nav a,
.pjk3-header .btn {
    letter-spacing: var(--pjk3-tracking-nav);
}

/* Tabler Icons — https://tabler.io/icons */
.pjk3-landing .ti {
    vertical-align: -0.125em;
    line-height: 1;
}

.pjk3-landing .btn .ti {
    font-size: 1.125em;
}

.pjk3-flow-icon.ti {
    font-size: 1.125rem;
}

body.pjk3-landing .container-xl {
    width: 100%;
    max-width: var(--pjk3-max);
    margin-inline: auto;
    padding-left: var(--pjk3-gutter-x);
    padding-right: var(--pjk3-gutter-x);
}

section[id] {
    scroll-margin-top: 80px;
}

/* Section spacing (PJK3 breathable layout) */
.pjk3-section {
    padding-block: var(--section-y);
}

.pjk3-section--md {
    padding-block: var(--section-y-md);
}

.pjk3-section-head {
    margin-bottom: var(--section-head-gap);
}

.pjk3-section-head .pjk3-section-title,
.pjk3-section-head .pjk3-section-title-light {
    margin-bottom: 0;
}

.pjk3-section-head .pjk3-eyebrow,
.pjk3-section-head .pjk3-eyebrow-light {
    margin-bottom: 0.5rem;
}

/* Header */
.pjk3-header {
    z-index: 1030;
    border-color: var(--border) !important;
    background: var(--header-bg) !important;
    backdrop-filter: blur(8px);
    transition:
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out),
        border-color var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-header.is-scrolled {
    box-shadow: var(--shadow-soft);
}

.dropdown-menu-pjk3 .dropdown-item.active {
    background: var(--maroon-soft);
    color: var(--maroon-dark);
    font-weight: 600;
}

.pjk3-logo-link {
    display: inline-flex;
    transition: transform var(--pjk3-duration) var(--pjk3-ease-out), opacity var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-logo-link:hover {
    transform: scale(1.04);
    opacity: 0.92;
}

.pjk3-logo {
    height: 40px;
    width: auto;
    object-fit: contain;
}

.pjk3-logo--footer {
    height: 40px;
}

.pjk3-nav a,
.nav-link-dropdown {
    color: var(--ink-muted);
    font-size: 0.875rem;
    font-weight: 500;
    text-decoration: none;
    transition: color var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-nav > a {
    position: relative;
}

.pjk3-nav > a::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -3px;
    width: 100%;
    height: 2px;
    background: var(--maroon);
    border-radius: 1px;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-nav a:hover,
.nav-link-dropdown:hover {
    color: var(--maroon);
}

.pjk3-nav > a:hover::after,
.pjk3-nav > a.is-active::after {
    transform: scaleX(1);
}

.pjk3-nav a.is-active,
.pjk3-nav .nav-link-dropdown.is-active {
    color: var(--maroon);
    font-weight: 600;
}

.pjk3-nav .nav-link-dropdown.is-active::before,
.pjk3-nav .dropdown.show > .nav-link-dropdown.is-active::before {
    transform: scaleX(1);
}

.nav-link-dropdown {
    position: relative;
}

.nav-link-dropdown::after {
    margin-left: 0.35rem;
}

.nav-link-dropdown::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: -3px;
    width: calc(100% - 1.1rem);
    height: 2px;
    background: var(--maroon);
    border-radius: 1px;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.dropdown:hover > .nav-link-dropdown::before,
.nav-link-dropdown:hover::before,
.nav-link-dropdown.show::before {
    transform: scaleX(1);
}

.dropdown-menu-pjk3 {
    min-width: 280px;
    border-radius: 0.75rem;
}

.dropdown-menu-pjk3 .dropdown-item {
    padding: 0.65rem 1rem;
    font-size: 0.875rem;
}

.dropdown-menu-pjk3 .dropdown-item {
    transition:
        background var(--pjk3-duration-fast) var(--pjk3-ease-out),
        color var(--pjk3-duration-fast) var(--pjk3-ease-out),
        padding-left var(--pjk3-duration-fast) var(--pjk3-ease-out);
}

.dropdown-menu-pjk3 .dropdown-item:hover {
    background: var(--maroon-soft);
    color: var(--maroon-dark);
    padding-left: 1.25rem;
}

.pjk3-mobile-nav a {
    display: block;
    padding: 0.85rem 0;
    border-bottom: 1px solid var(--border-soft);
    color: var(--ink-muted);
    text-decoration: none;
    font-weight: 500;
    transition: color var(--pjk3-duration-fast) var(--pjk3-ease-out), padding-left var(--pjk3-duration-fast) var(--pjk3-ease-out);
}

.pjk3-mobile-nav a:hover {
    color: var(--maroon);
    padding-left: 0.35rem;
}

.pjk3-mobile-nav a.is-active {
    color: var(--maroon-dark);
    font-weight: 600;
    padding-left: 0.35rem;
}

.pjk3-mobile-nav a:active {
    color: var(--maroon);
    padding-left: 0.25rem;
}

.pjk3-mobile-nav-toggle.is-active {
    color: var(--maroon-dark);
}

.pjk3-mobile-nav-sub a.is-active {
    color: var(--maroon-dark);
    font-weight: 600;
}

.pjk3-mobile-nav-group {
    border-bottom: 1px solid var(--border-soft);
}

.pjk3-mobile-nav-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    width: 100%;
    padding: 0.85rem 0;
    border: none;
    background: none;
    color: var(--ink-muted);
    font-family: var(--pjk3-font-heading);
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: var(--pjk3-tracking-nav);
    text-align: left;
    transition: color var(--pjk3-duration-fast) var(--pjk3-ease-out);
}

.pjk3-mobile-nav-toggle:hover,
.pjk3-mobile-nav-toggle:focus {
    color: var(--maroon);
}

.pjk3-mobile-nav-toggle[aria-expanded="true"] {
    color: var(--maroon);
}

.pjk3-mobile-nav-chevron {
    font-size: 1.125rem;
    flex-shrink: 0;
    transition: transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-mobile-nav-toggle[aria-expanded="true"] .pjk3-mobile-nav-chevron {
    transform: rotate(180deg);
}

.pjk3-mobile-nav-sub {
    padding-bottom: 0.35rem;
}

.pjk3-mobile-nav-sub a {
    padding: 0.65rem 0 0.65rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--ink-muted);
    border-bottom: none;
}

.pjk3-mobile-nav-sub a:last-child {
    padding-bottom: 0.85rem;
}

.pjk3-mobile-nav-sub a:hover {
    padding-left: 1.2rem;
}

.pjk3-mobile-nav .btn {
    width: 100%;
    display: inline-flex;
    margin-top: 0.75rem;
    margin-bottom: var(--btn-3d-y);
    white-space: normal;
    text-align: center;
}

.pjk3-mobile-nav .btn + .btn {
    margin-top: 0.625rem;
}

.pjk3-mobile-nav .btn-pjk3-outline.pjk3-theme-toggle {
    --btn-edge: #d0d5db;
    --btn-edge-active: #b8bec6;
    color: var(--ink) !important;
}

.pjk3-mobile-nav .btn-pjk3-outline.pjk3-theme-toggle:hover,
.pjk3-mobile-nav .btn-pjk3-outline.pjk3-theme-toggle:focus {
    color: var(--maroon-dark) !important;
}

/* Mobile menu — full screen */
.pjk3-mobile-menu.offcanvas {
    --bs-offcanvas-width: 100%;
    width: 100% !important;
    max-width: 100% !important;
    border: none;
}

.pjk3-mobile-menu .offcanvas-header {
    padding: 1rem var(--pjk3-gutter-x);
    border-bottom: 1px solid var(--border-soft);
}

.pjk3-mobile-menu .offcanvas-body {
    padding: 0 var(--pjk3-gutter-x) calc(1.5rem + var(--btn-3d-y));
    display: flex;
    flex-direction: column;
}

.pjk3-mobile-menu .pjk3-mobile-nav {
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.offcanvas-backdrop.show {
    opacity: 0.55;
}

body.pjk3-landing.offcanvas-open .pjk3-wa-float {
    opacity: 0;
    pointer-events: none;
}

.offcanvas-body {
    padding-bottom: 1.25rem;
}

/* Buttons — ukuran seragam (primary, green brand, WA) */
.btn-pjk3-primary,
.btn-pjk3-outline,
.btn-pjk3-wa,
.btn-pjk3-green,
.btn-pjk3-outline-green,
.btn-accent-green,
.btn-pjk3-light,
.btn-pjk3-outline-light {
    --bs-btn-padding-y: 0.5rem;
    --bs-btn-padding-x: 1.125rem;
    --bs-btn-font-size: 0.875rem;
    --bs-btn-line-height: 1.25;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    min-height: 2.5rem;
    padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.25;
    border-radius: var(--btn-radius);
    border-width: 1px;
    border-style: solid;
    box-sizing: border-box;
    white-space: nowrap;
    vertical-align: middle;
    -webkit-tap-highlight-color: transparent;
    transition:
        background var(--pjk3-duration-fast) var(--pjk3-ease-out),
        border-color var(--pjk3-duration-fast) var(--pjk3-ease-out),
        color var(--pjk3-duration-fast) var(--pjk3-ease-out),
        filter var(--pjk3-duration-fast) var(--pjk3-ease-out),
        transform var(--pjk3-duration-fast) var(--pjk3-ease-out);
}

.btn-pjk3-primary:active:not(:disabled),
.btn-pjk3-wa:active:not(:disabled),
.btn-pjk3-green:active:not(:disabled),
.btn-accent-green:active:not(:disabled),
.btn-pjk3-outline:active:not(:disabled),
.btn-pjk3-light:active:not(:disabled) {
    transform: scale(0.98);
}

.btn-pjk3-primary .ti-arrow-right,
.btn-pjk3-primary .ti-arrow-up-right,
.btn-pjk3-green .ti-arrow-right,
.btn-accent-green .ti-arrow-right,
.btn-pjk3-outline .ti-arrow-right,
.btn-pjk3-light .ti-arrow-right,
.btn-pjk3-outline-light .ti-arrow-right,
.btn-pjk3-wa .ti-arrow-right {
    transition: transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.btn-pjk3-primary:hover .ti-arrow-right,
.btn-pjk3-primary:hover .ti-arrow-up-right,
.btn-pjk3-green:hover .ti-arrow-right,
.btn-accent-green:hover .ti-arrow-right,
.btn-pjk3-outline:hover .ti-arrow-right,
.btn-pjk3-light:hover .ti-arrow-right,
.btn-pjk3-outline-light:hover .ti-arrow-right,
.btn-pjk3-wa:hover .ti-arrow-right {
    transform: translate(3px, -2px);
}

/* Depth Selia — inset atas + edge bawah */
.btn-pjk3-primary,
.btn-pjk3-outline,
.btn-pjk3-wa,
.btn-pjk3-green,
.btn-pjk3-outline-green,
.btn-accent-green,
.btn-pjk3-light,
.btn-pjk3-outline-light {
    box-shadow:
        inset 0 1px 0 var(--btn-highlight),
        0 var(--btn-3d-y) 0 var(--btn-edge, var(--btn-3d-edge));
}

a.btn.btn-pjk3-primary,
button.btn.btn-pjk3-primary,
a.btn.btn-pjk3-wa,
button.btn.btn-pjk3-wa,
a.btn.btn-pjk3-green,
button.btn.btn-pjk3-green,
a.btn.btn-accent-green,
button.btn.btn-accent-green {
    color: #fff !important;
}

a.btn.btn-pjk3-primary:visited,
a.btn.btn-pjk3-wa:visited,
a.btn.btn-pjk3-green:visited,
a.btn.btn-accent-green:visited {
    color: #fff !important;
}

.btn-pjk3-primary.btn-sm,
.btn-pjk3-outline.btn-sm,
.btn-pjk3-wa.btn-sm,
.btn-pjk3-green.btn-sm,
.btn-pjk3-outline-green.btn-sm,
.btn-accent-green.btn-sm,
.btn-pjk3-light.btn-sm,
.btn-pjk3-outline-light.btn-sm {
    --bs-btn-padding-y: 0.4375rem;
    --bs-btn-padding-x: 1rem;
    --bs-btn-font-size: 0.875rem;
    --bs-btn-line-height: 1.25;
    min-height: 2.375rem;
    font-size: 0.875rem;
}

.btn-pjk3-primary.btn-lg,
.btn-pjk3-outline.btn-lg,
.btn-pjk3-wa.btn-lg,
.btn-pjk3-green.btn-lg,
.btn-pjk3-outline-green.btn-lg,
.btn-accent-green.btn-lg,
.btn-pjk3-light.btn-lg,
.btn-pjk3-outline-light.btn-lg {
    --bs-btn-padding-y: 0.625rem;
    --bs-btn-padding-x: 1.5rem;
    --bs-btn-font-size: 1rem;
    --bs-btn-line-height: 1.25;
    min-height: 3rem;
    font-size: 1rem;
}

/* Tombol Selia — gradasi + warna edge */
.btn-pjk3-primary {
    --btn-edge: var(--maroon-dark);
    --btn-edge-active: #2a0810;
    --btn-highlight: rgba(255, 255, 255, 0.26);
    background: linear-gradient(180deg, #9e2125 0%, var(--maroon) 50%, var(--maroon-dark) 100%);
    border-color: #731518;
    color: #fff;
}

.btn-pjk3-primary:hover,
.btn-pjk3-primary:focus {
    background: linear-gradient(180deg, #a82529 0%, var(--maroon-dark) 50%, #4d0a0d 100%);
    border-color: #5c1013;
    color: #fff;
}

.btn-pjk3-green,
.btn-accent-green {
    --btn-edge: var(--green-dark);
    --btn-edge-active: #0f4d2e;
    --btn-highlight: rgba(255, 255, 255, 0.28);
    background: linear-gradient(180deg, #248f56 0%, var(--green) 50%, var(--green-dark) 100%);
    border-color: #1a6b40;
    color: #fff;
}

.btn-pjk3-green:hover,
.btn-pjk3-green:focus,
.btn-accent-green:hover,
.btn-accent-green:focus {
    background: linear-gradient(180deg, #2a9a5f 0%, var(--green-dark) 50%, #124a2d 100%);
    border-color: #155f37;
    color: #fff;
}

.btn-pjk3-outline {
    --btn-edge: var(--btn-3d-edge);
    --btn-edge-active: #b0b6be;
    --btn-highlight: rgba(255, 255, 255, 0.9);
    background: linear-gradient(180deg, #ffffff 0%, #f8f9fa 100%);
    border-color: #d8dde3;
    color: var(--ink-muted);
}

.btn-pjk3-outline:hover,
.btn-pjk3-outline:focus {
    background: linear-gradient(180deg, #fff 0%, var(--maroon-soft) 100%);
    border-color: var(--maroon-muted);
    color: var(--maroon-dark);
}

.btn-pjk3-light {
    --btn-edge: #d1d5db;
    --btn-edge-active: #c5cad0;
    background: linear-gradient(180deg, #ffffff 0%, #f4f5f6 100%);
    border-color: #e2e6ea;
    color: var(--maroon);
}

.btn-pjk3-light:hover,
.btn-pjk3-light:focus {
    background: linear-gradient(180deg, #fff 0%, var(--maroon-soft) 100%);
    border-color: var(--maroon-muted);
    color: var(--maroon-dark);
}

.btn-pjk3-outline-light {
    --btn-edge: rgba(0, 0, 0, 0.22);
    --btn-edge-active: rgba(0, 0, 0, 0.22);
    --btn-highlight: rgba(255, 255, 255, 0.2);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0.04) 100%);
    border-color: rgba(255, 255, 255, 0.65);
    color: #fff;
}

.btn-pjk3-outline-light:hover,
.btn-pjk3-outline-light:focus {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0.08) 100%);
    border-color: #fff;
    color: #fff;
}

/* Tombol terang di band maroon (layanan & CTA) */
.pjk3-cta .btn-pjk3-light,
.pjk3-solutions .btn-pjk3-light {
    --btn-edge: #b0b6be;
    --btn-edge-active: #9aa3ad;
    --btn-highlight: rgba(255, 255, 255, 0.95);
    background: linear-gradient(180deg, #ffffff 0%, #f2f4f6 100%);
    border-color: #e8ebef;
    color: var(--maroon-dark);
}

.pjk3-cta .btn-pjk3-light:hover,
.pjk3-solutions .btn-pjk3-light:hover,
.pjk3-cta .btn-pjk3-light:focus,
.pjk3-solutions .btn-pjk3-light:focus {
    background: linear-gradient(180deg, #fff 0%, #f8f4f5 100%);
    border-color: #e0d5d9;
    color: var(--maroon);
}

.pjk3-header-actions {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-shrink: 0;
}

.text-accent-green {
    color: var(--green-dark) !important;
}

.text-accent-maroon {
    color: var(--maroon) !important;
}

::selection {
    background: var(--maroon-soft);
    color: var(--maroon-dark);
}

/* Hero — full-width top band (bukan card) */
.pjk3-hero {
    background: var(--surface-elevated);
}

.pjk3-hero-top {
    position: relative;
    width: 100%;
    overflow: hidden;
    background:
        radial-gradient(ellipse 75% 55% at 100% 0%, rgba(var(--maroon-rgb), 0.08) 0%, transparent 58%),
        radial-gradient(ellipse 45% 40% at 0% 100%, rgba(var(--green-rgb), 0.06) 0%, transparent 52%),
        linear-gradient(180deg, var(--surface-elevated) 0%, var(--surface) 100%);
    border-bottom: 1px solid var(--border-soft);
}

.pjk3-hero-top-inner {
    position: relative;
    z-index: 1;
    min-height: 240px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2rem 0 2.5rem;
}

@media (min-width: 992px) {
    .pjk3-hero-top-inner {
        min-height: 280px;
        padding: 2.5rem 0 3.25rem;
    }
}

.pjk3-hero-title {
    font-size: clamp(2rem, 4.25vw, 3.75rem);
    line-height: 1.08;
    letter-spacing: var(--pjk3-tracking-heading-lg);
    font-weight: 600;
    color: var(--ink);
}

.pjk3-hero-sub {
    font-size: 0.9375rem;
    color: var(--pjk3-gray-500);
    line-height: 1.65;
}

@media (min-width: 992px) {
    .pjk3-hero-sub {
        font-size: 1.0625rem;
    }
}

.pjk3-hero-cta-group {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
    width: 100%;
    margin-top: 1.5rem;
}

@media (min-width: 768px) {
    .pjk3-hero-cta-group {
        flex-direction: row;
        align-items: stretch;
        margin-top: 2rem;
    }

    .pjk3-hero-cta-group .btn {
        flex: 1 1 0;
        min-width: 0;
    }

    .pjk3-hero-cta-group--2 {
        max-width: 28rem;
    }

    .pjk3-hero-cta-group--3 {
        max-width: 42rem;
    }
}

.pjk3-hero-cta-group .btn {
    width: 100%;
    min-height: 2.75rem;
    justify-content: center;
    white-space: nowrap;
    font-size: 0.8125rem;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
}

@media (min-width: 992px) {
    .pjk3-hero-cta-group .btn {
        font-size: 0.875rem;
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

.btn-pjk3-wa {
    --btn-edge: #128c3a;
    --btn-edge-active: #0d6e32;
    --btn-highlight: rgba(255, 255, 255, 0.34);
    background: linear-gradient(180deg, #2ee07a 0%, #25d366 50%, #1aad55 100%);
    border-color: #20b85c;
    color: #fff;
}

.btn-pjk3-wa:hover,
.btn-pjk3-wa:focus {
    background: linear-gradient(180deg, #2adb70 0%, #1fb355 50%, #18964a 100%);
    border-color: #1aad55;
    color: #fff;
}

.btn-pjk3-outline-green {
    --btn-edge: var(--btn-3d-edge);
    --btn-edge-active: #b0b6be;
    --btn-highlight: rgba(255, 255, 255, 0.88);
    background: linear-gradient(180deg, #ffffff 0%, #f0f8f4 100%);
    border-color: var(--green-muted);
    color: var(--green-dark);
}

.btn-pjk3-outline-green:hover,
.btn-pjk3-outline-green:focus {
    background: linear-gradient(180deg, #f8fdf9 0%, var(--green-soft) 100%);
    border-color: var(--green);
    color: var(--green-dark);
}

.pjk3-hero-industries {
    padding-block: var(--section-y);
    background: var(--surface);
}

.pjk3-hero-industries .pjk3-trusted-label {
    margin-bottom: var(--section-head-gap) !important;
}

.pjk3-hero-media {
    position: relative;
    overflow: hidden;
}

.pjk3-hero-img {
    display: block;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: center 40%;
}

@media (min-width: 992px) {
    .pjk3-hero-img {
        aspect-ratio: 8 / 3;
        object-position: center center;
    }
}

.pjk3-hero-video-wrap {
    position: relative;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: var(--surface-elevated);
}

@media (min-width: 992px) {
    .pjk3-hero-video-wrap {
        aspect-ratio: 8 / 3;
    }
}

.pjk3-hero-video {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 300%;
    height: 300%;
    transform: translate(-50%, -50%);
    border: 0;
    pointer-events: none;
}

.pjk3-hero-video-fallback {
    display: none;
}

@media (prefers-reduced-motion: reduce) {
    .pjk3-hero-video-wrap {
        display: none;
    }

    .pjk3-hero-video-fallback {
        display: block;
    }
}

.pjk3-trusted-label {
    font-size: 0.75rem;
    letter-spacing: 0.25em;
    color: var(--pjk3-gray-500);
    max-width: 80%;
    line-height: 1.4;
}

@media (min-width: 992px) {
    .pjk3-trusted-label {
        font-size: 1.125rem;
        letter-spacing: 0.2em;
    }
}

/* Marquee */
.pjk3-marquee {
    overflow: hidden;
    mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

.pjk3-marquee-track {
    display: flex;
    align-items: center;
    gap: 2rem;
    width: max-content;
    animation: pjk3-marquee 40s linear infinite;
}

.pjk3-partner-logo {
    height: 48px;
    width: auto;
    padding: 0 2rem;
    object-fit: contain;
    flex-shrink: 0;
    opacity: 0.72;
    filter: grayscale(1);
    transition:
        opacity var(--pjk3-duration) var(--pjk3-ease-out),
        filter var(--pjk3-duration) var(--pjk3-ease-out),
        transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-partner-logo:hover {
    opacity: 1;
    filter: grayscale(0);
    transform: scale(1.08);
}

.pjk3-industry-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 1.25rem;
    margin: 0 0.5rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface-elevated);
    color: var(--ink-muted);
    font-size: 0.875rem;
    font-weight: 500;
    white-space: nowrap;
    flex-shrink: 0;
    transition:
        border-color var(--pjk3-duration) var(--pjk3-ease-out),
        background var(--pjk3-duration) var(--pjk3-ease-out),
        color var(--pjk3-duration) var(--pjk3-ease-out),
        transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-industry-chip:hover {
    border-color: var(--maroon-muted);
    background: var(--maroon-soft);
    color: var(--maroon-dark);
    transform: translateY(-2px);
}

.pjk3-marquee-chips .pjk3-marquee-track {
    gap: 0;
}

.pjk3-solution-desc {
    line-height: 1.4;
}

.pjk3-flow {
    background: transparent;
}

.pjk3-flow-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: relative;
    padding: 0;
    margin: 0;
    list-style: none;
}

.pjk3-flow-step {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    column-gap: 1.25rem;
    row-gap: 0.35rem;
    padding: 0 0 2rem 0;
    padding-left: 0.25rem;
}

.pjk3-flow-step:last-child {
    padding-bottom: 0;
}

.pjk3-flow-step::before {
    content: '';
    position: absolute;
    left: 1.375rem;
    top: 3.25rem;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, var(--maroon-muted) 0%, transparent 100%);
    transform: translateX(-50%);
}

.pjk3-flow-step:last-child::before {
    display: none;
}

.pjk3-flow-node {
    grid-row: 1 / span 2;
    grid-column: 1;
    position: relative;
    z-index: 1;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    background: var(--maroon);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out);
    flex-shrink: 0;
    box-shadow: 0 0 0 4px var(--surface-elevated), 0 0 0 5px rgba(var(--maroon-rgb), 0.4);
}

.pjk3-flow-num {
    position: absolute;
    top: -0.35rem;
    right: -0.35rem;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 0.25rem;
    border-radius: 999px;
    background: var(--maroon-dark);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
    font-size: 0.625rem;
    font-weight: 700;
    line-height: 1.25rem;
    text-align: center;
}

.pjk3-flow-icon {
    font-size: 1.125rem;
}

.pjk3-flow-title {
    grid-column: 2;
    grid-row: 1;
    align-self: end;
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--ink);
    line-height: 1.3;
    letter-spacing: var(--pjk3-tracking-heading);
    transition: color var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-flow-desc {
    grid-column: 2;
    grid-row: 2;
    margin: 0;
    font-size: 0.8125rem;
    color: var(--pjk3-gray-500);
    line-height: 1.5;
}

.pjk3-flow-step:hover .pjk3-flow-node {
    transform: scale(1.1);
    box-shadow: 0 6px 18px rgba(var(--maroon-rgb), 0.35);
}

.pjk3-flow-step:hover .pjk3-flow-title {
    color: var(--maroon-dark);
}

@media (min-width: 1200px) {
    .pjk3-flow-timeline {
        flex-direction: row;
        align-items: flex-start;
        gap: 0;
        padding-top: 0.5rem;
    }

    .pjk3-flow-timeline::before {
        content: '';
        position: absolute;
        top: 1.375rem;
        left: calc(100% / 14);
        right: calc(100% / 14);
        height: 2px;
        background: linear-gradient(
            90deg,
            var(--maroon-muted) 0%,
            var(--maroon) 50%,
            var(--maroon-muted) 100%
        );
        z-index: 0;
    }

    .pjk3-flow-step {
        flex: 1 1 0;
        min-width: 0;
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 0 0.5rem 0;
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
    }

    .pjk3-flow-step::before {
        display: none;
    }

    .pjk3-flow-node {
        grid-row: auto;
        grid-column: auto;
        width: 3rem;
        height: 3rem;
        margin-bottom: 1rem;
    }

    .pjk3-flow-icon {
        font-size: 1.25rem;
    }

    .pjk3-flow-title {
        grid-column: auto;
        grid-row: auto;
        align-self: auto;
        font-size: 0.875rem;
        margin-bottom: 0.35rem;
    }

    .pjk3-flow-desc {
        grid-column: auto;
        grid-row: auto;
        font-size: 0.75rem;
        max-width: 11rem;
        margin: 0 auto;
    }
}

@media (min-width: 768px) and (max-width: 1199.98px) {
    .pjk3-flow-timeline {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem 2rem;
    }

    .pjk3-flow-step {
        padding-bottom: 0;
        padding-left: 0;
    }

    .pjk3-flow-step::before {
        display: none;
    }

    .pjk3-flow-step:nth-child(odd):last-child,
    .pjk3-flow-step:last-child:nth-child(odd) {
        grid-column: 1 / -1;
        max-width: 50%;
        justify-self: center;
    }
}

.pjk3-feature-card {
    position: relative;
    border: 1px solid var(--border) !important;
    background: var(--surface-elevated) !important;
    box-shadow: var(--shadow-soft);
    border-radius: var(--radius);
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        border-color var(--pjk3-duration) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out),
        background var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-feature-card--row {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.25rem 1.35rem 1.25rem 1.15rem;
}

.pjk3-feature-card--row .pjk3-feature-icon {
    margin-bottom: 0;
    flex-shrink: 0;
}

.pjk3-feature-body {
    flex: 1;
    min-width: 0;
    padding-top: 0.15rem;
    padding-right: 1.75rem;
}

.pjk3-feature-num {
    position: absolute;
    top: 1rem;
    right: 1.1rem;
    font-family: var(--font-display);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--maroon);
    opacity: 0.45;
}

.pjk3-feature-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 0.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    transition:
        background var(--pjk3-duration) var(--pjk3-ease-out),
        color var(--pjk3-duration) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out),
        transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-feature-icon.is-maroon {
    background: var(--maroon-soft);
    color: var(--maroon);
}

.pjk3-feature-icon.is-green {
    background: var(--green-soft);
    color: var(--green-dark);
}

.pjk3-feature-icon .ti {
    font-size: 1.35rem;
    line-height: 1;
    transition: transform var(--pjk3-duration) var(--pjk3-ease-out);
}

@media (hover: hover) and (pointer: fine) {
    .pjk3-feature-card:hover {
        border-color: var(--maroon-muted) !important;
        background: linear-gradient(165deg, #fff 0%, var(--maroon-soft) 100%) !important;
        box-shadow:
            var(--pjk3-shadow-hover),
            inset 0 1px 0 rgba(255, 255, 255, 0.85);
        transform: translateY(-4px);
    }

    .pjk3-feature-card--row:hover {
        transform: none;
        background: #fff !important;
        box-shadow: 0 10px 28px rgba(var(--maroon-rgb), 0.12);
    }

    .pjk3-feature-card:hover .pjk3-feature-icon.is-maroon {
        background: var(--maroon);
        color: #fff;
        box-shadow: 0 8px 20px rgba(var(--maroon-rgb), 0.28);
        transform: translateY(-2px);
    }

    .pjk3-feature-card:hover .pjk3-feature-icon.is-green {
        background: var(--green-dark);
        color: #fff;
        box-shadow: 0 8px 20px rgba(28, 122, 71, 0.28);
        transform: translateY(-2px);
    }

    .pjk3-feature-card:hover .pjk3-feature-icon .ti {
        transform: scale(1.08);
    }
}

@keyframes pjk3-marquee {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

/* Typography blocks */
.pjk3-section-title {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 600;
    line-height: 1.25;
    color: var(--ink);
    letter-spacing: var(--pjk3-tracking-heading);
}

.pjk3-section-title-light {
    font-size: clamp(1.75rem, 3vw, 3rem);
    font-weight: 600;
    line-height: 1.2;
    color: #fff;
    letter-spacing: var(--pjk3-tracking-heading);
}

.pjk3-eyebrow {
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--maroon);
    font-weight: 600;
}

.pjk3-eyebrow-light {
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.9);
}

/* Stat cards */
.pjk3-stat-card {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-soft);
    background: url('../brand/bg-card.png') center / cover no-repeat;
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 140px;
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out),
        border-color var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-stat-card:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: var(--pjk3-shadow-hover);
    border-color: var(--maroon-muted);
}

@media (min-width: 992px) {
    .pjk3-stat-card {
        aspect-ratio: auto;
        min-height: 180px;
    }
}

.pjk3-stat-num {
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    font-weight: 600;
    padding: 1rem 1.25rem 0;
    color: var(--maroon);
}

.pjk3-stat-label {
    font-size: 0.875rem;
    color: var(--pjk3-gray-500);
    background: var(--surface);
    padding: 0.75rem 1rem;
    border-radius: 0 0 0.75rem 0.75rem;
}

/* Solutions band */
.pjk3-solutions {
    background: var(--pjk3-section-bg);
    padding-bottom: calc(var(--section-dark-y) + 1rem);
}

.pjk3-solutions .pjk3-section-title-light {
    font-size: clamp(1.75rem, 4vw, 3rem);
    line-height: 1.2;
}

.pjk3-swiper-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem;
    background: #fff;
    border: none;
    border-radius: 0.5rem;
    color: var(--maroon-dark);
    font-size: 1.25rem;
    line-height: 1;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}

.pjk3-swiper-btn:hover {
    background: #f0e8ea;
    color: var(--maroon);
}

.pjk3-swiper-btn:disabled,
.pjk3-swiper-btn.swiper-button-disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.pjk3-layanan-grid .pjk3-solution-card {
    height: 100%;
}

.pjk3-layanan-grid .pjk3-solution-title {
    font-size: clamp(0.9375rem, 1.6vw, 1.125rem);
}

.pjk3-layanan-grid .pjk3-solution-desc {
    display: none;
    line-height: 1.4;
}

@media (min-width: 992px) {
    .pjk3-layanan-grid .pjk3-solution-desc {
        display: block;
    }
}

.pjk3-solution-card {
    border-radius: 0.75rem;
    overflow: hidden;
    position: relative;
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-solution-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
}

.pjk3-solution-img {
    width: 100%;
    aspect-ratio: 3 / 5;
    object-fit: cover;
    border-radius: 0.75rem;
    transition: filter var(--pjk3-duration-slow) var(--pjk3-ease-out), transform var(--pjk3-duration-slow) var(--pjk3-ease-out);
}

.pjk3-solution-card:hover .pjk3-solution-img {
    filter: blur(3px);
    transform: scale(1.06);
}

.pjk3-solution-more .ti-arrow-right {
    display: inline-block;
    transition: transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-solution-card:hover .pjk3-solution-more .ti-arrow-right {
    transform: translateX(5px);
}

@media (min-width: 992px) {
    .pjk3-solution-img {
        aspect-ratio: 3 / 4;
    }
}

.pjk3-solution-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.55), transparent 50%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1.5rem 1rem 2rem;
    transition: background var(--pjk3-duration-slow) var(--pjk3-ease-out);
}

.pjk3-solution-card:hover .pjk3-solution-overlay {
    background: linear-gradient(to top, rgba(0, 0, 0, 0.72), transparent 55%);
}

.pjk3-solution-title {
    color: #fff;
    font-weight: 500;
    font-size: 1.25rem;
    margin: 0;
}

.pjk3-solution-more {
    color: #fff;
    font-weight: 500;
    font-size: 0.9rem;
    margin-top: 0.5rem;
    opacity: 0;
    transform: translateY(1rem);
    transition:
        opacity var(--pjk3-duration-slow) var(--pjk3-ease-out),
        transform var(--pjk3-duration-slow) var(--pjk3-ease-out);
}

.pjk3-solution-card:hover .pjk3-solution-more {
    opacity: 1;
    transform: translateY(0);
}

.pjk3-swiper-pagination {
    bottom: -2.5rem !important;
}

.pjk3-swiper-pagination .swiper-pagination-bullet {
    background: rgba(255, 255, 255, 0.5) !important;
    opacity: 1 !important;
}

.pjk3-swiper-pagination .swiper-pagination-bullet-active {
    background: #fff !important;
}

/* Case study */
.pjk3-case-card {
    display: block;
    width: 100%;
    padding: 0;
    border: none;
    background: none;
    border-radius: 0.5rem;
    overflow: hidden;
    position: relative;
    aspect-ratio: 1;
    cursor: pointer;
    text-align: inherit;
    color: inherit;
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-case-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--pjk3-shadow-hover-lg);
}

.pjk3-case-card:focus-visible {
    outline: 2px solid var(--maroon);
    outline-offset: 3px;
}

.pjk3-case-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--pjk3-duration-slow) var(--pjk3-ease-out);
}

.pjk3-case-card:hover img {
    transform: scale(1.08);
}

.pjk3-case-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.6), transparent);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 1rem;
    color: #fff;
    transition: background var(--pjk3-duration-slow) var(--pjk3-ease-out);
}

.pjk3-case-card:hover .pjk3-case-overlay {
    background: linear-gradient(to top, rgba(0, 0, 0, 0.75), transparent 50%);
}

.pjk3-case-overlay p {
    font-weight: 500;
    font-size: 1.25rem;
    transform: translateY(1rem);
    transition: transform var(--pjk3-duration-slow) var(--pjk3-ease-out);
}

.pjk3-case-more {
    font-weight: 500;
    opacity: 0;
    transition: opacity var(--pjk3-duration-slow) var(--pjk3-ease-out);
}

.pjk3-case-more .ti-arrow-right {
    display: inline-block;
    transition: transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-case-card:hover .pjk3-case-more .ti-arrow-right {
    transform: translateX(5px);
}

.pjk3-case-card:hover .pjk3-case-overlay p {
    transform: translateY(0);
}

.pjk3-case-card:hover .pjk3-case-more {
    opacity: 1;
}

/* Testimonials */
.pjk3-testi-card {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-soft);
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out),
        border-color var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-testi-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--pjk3-shadow-hover);
    border-color: var(--maroon-muted);
}

.pjk3-testi-foot {
    background: var(--surface);
    border-top: 1px solid var(--border-soft);
}

.pjk3-testi-grid .pjk3-testi-card {
    min-height: 100%;
}

.pjk3-testi-slider {
    position: relative;
}

.pjk3-testi-swiper {
    overflow: hidden;
    padding-block: 0.75rem;
    margin-block: -0.75rem;
}

.pjk3-testi-swiper .swiper-slide {
    height: auto;
    box-sizing: border-box;
}

.pjk3-testi-swiper .pjk3-testi-card {
    min-height: 100%;
}

@media (hover: hover) and (pointer: fine) {
    .pjk3-testi-swiper .pjk3-testi-card:hover {
        transform: none;
        border-color: var(--maroon-muted);
        box-shadow: 0 8px 24px rgba(var(--maroon-rgb), 0.12);
    }
}

.pjk3-testi-swiper.swiper-grabbing .pjk3-testi-card,
.pjk3-testi-swiper.swiper-grabbing .pjk3-testi-card:hover {
    transform: none;
    border-color: var(--border);
    box-shadow: var(--shadow-soft);
}

@media (hover: none) {
    .pjk3-testi-swiper .pjk3-testi-card:hover {
        transform: none;
        border-color: var(--border);
        box-shadow: var(--shadow-soft);
    }
}

.pjk3-testi-pagination {
    position: static !important;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    width: auto !important;
    margin-top: 1.75rem;
}

.pjk3-testi-pagination .swiper-pagination-bullet {
    width: 0.5rem;
    height: 0.5rem;
    margin: 0 !important;
    background: var(--border) !important;
    opacity: 1 !important;
    transition: background var(--pjk3-duration-fast) var(--pjk3-ease-out), transform var(--pjk3-duration-fast) var(--pjk3-ease-out);
}

.pjk3-testi-pagination .swiper-pagination-bullet-active {
    background: var(--maroon) !important;
    transform: scale(1.15);
}

/* Badges */
.pjk3-badge {
    background: var(--surface-elevated);
    border: 1px solid var(--border);
    color: var(--ink-muted);
    font-weight: 500;
    padding: 0.5rem 0.85rem;
    font-size: 0.8125rem;
}

.pjk3-badge:hover {
    border-color: var(--maroon-muted);
    background: var(--maroon-soft);
    color: var(--maroon-dark);
}

/* FAQ */
.pjk3-faq-aside {
    position: sticky;
    top: calc(5.5rem + 1rem);
    padding: 1.75rem;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 1rem;
    box-shadow: var(--shadow-card);
}

.pjk3-faq-aside-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 0.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    background: var(--maroon-soft);
    color: var(--maroon);
}

.pjk3-faq-aside-icon .ti {
    font-size: 1.35rem;
    line-height: 1;
}

.pjk3-faq-item {
    background: #fff;
    border-color: var(--border) !important;
    box-shadow: var(--shadow-card);
    overflow: hidden;
}

.pjk3-faq-item .accordion-header {
    border-bottom: 0;
}

.pjk3-faq-item .accordion-button {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.125rem 1.25rem;
    font-weight: 600;
    background: #fff;
    border: 0;
    box-shadow: none;
    border-radius: 0;
}

.pjk3-faq-item .accordion-button.collapsed {
    border-radius: calc(0.75rem - 1px);
}

.pjk3-faq-item .accordion-button:not(.collapsed) {
    border-bottom: 0;
    border-radius: 0;
}

.pjk3-faq-item .accordion-collapse {
    border: 0;
}

.pjk3-faq-num {
    flex-shrink: 0;
    font-family: var(--font-display);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--maroon);
    min-width: 1.75rem;
    padding-top: 0.2rem;
}

.pjk3-faq-q {
    flex: 1;
    min-width: 0;
    text-align: left;
    line-height: 1.45;
}

.pjk3-faq-item .accordion-body {
    padding: 1rem 1.25rem 1.375rem 3.5rem;
    line-height: 1.65;
    border-top: 0;
    background: #fff;
}

.pjk3-faq-list .accordion-button::after {
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%238a1c2b'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%238a1c2b'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    filter: none;
}

.pjk3-accordion .accordion-button {
    transition:
        background var(--pjk3-duration-fast) var(--pjk3-ease-out),
        color var(--pjk3-duration-fast) var(--pjk3-ease-out);
}

.pjk3-accordion .accordion-button:hover {
    background: var(--maroon-soft);
    color: var(--maroon-dark);
}

.pjk3-accordion .accordion-button:not(.collapsed) {
    background: var(--maroon-soft);
    color: var(--maroon-dark);
    box-shadow: none;
    border-bottom: 0;
}

.pjk3-accordion .accordion-button:focus {
    box-shadow: 0 0 0 0.2rem rgba(var(--maroon-rgb), 0.22);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--maroon);
    box-shadow: 0 0 0 0.2rem rgba(var(--maroon-rgb), 0.18);
}

/* CTA */
.pjk3-cta {
    background: var(--pjk3-section-bg);
    padding-block: var(--section-cta-y);
}

@media (max-width: 991.98px) {
    .pjk3-cta {
        padding-block: 3rem;
    }

    .pjk3-cta .row {
        text-align: center;
        --bs-gutter-y: 1.5rem;
    }

    .pjk3-cta .pjk3-section-title-light {
        font-size: clamp(1.375rem, 5.5vw, 1.75rem);
        line-height: 1.25;
        margin-bottom: 0.75rem !important;
    }

    .pjk3-cta .text-white-50 {
        color: rgba(255, 255, 255, 0.82) !important;
        line-height: 1.6;
        max-width: 22rem;
        margin-inline: auto;
    }

    .pjk3-cta .col-lg-auto {
        width: 100%;
        flex-direction: column !important;
        align-items: stretch !important;
        flex-wrap: nowrap !important;
        gap: 0.75rem !important;
    }

    .pjk3-cta .col-lg-auto .btn {
        width: 100%;
        justify-content: center;
        min-height: 3rem;
        white-space: normal;
    }
}

/* Footer — putih, ringkas */
.pjk3-footer {
    padding-block: 3rem 1.75rem;
    background: var(--surface-elevated) !important;
    border-top: 1px solid var(--border) !important;
    color: var(--ink);
}

.pjk3-footer-label {
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-muted);
    margin-bottom: 1rem;
}

.pjk3-footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.pjk3-footer-links a {
    display: inline-block;
    color: var(--ink);
    text-decoration: none;
    font-size: 0.9375rem;
    font-weight: 500;
    transition:
        color var(--pjk3-duration) var(--pjk3-ease-out),
        transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-footer-links li + li {
    margin-top: 0.5rem;
}

.pjk3-footer-links a:hover {
    color: var(--maroon);
    transform: translateX(4px);
}

.pjk3-footer-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    width: 100%;
    margin-top: 2rem;
    padding: 1rem 1.25rem;
    text-decoration: none;
    text-align: left;
    border-radius: var(--btn-radius);
    background: var(--maroon);
    border: 1px solid var(--maroon);
    color: #fff !important;
    box-shadow: none;
    transition:
        background 0.15s ease,
        border-color 0.15s ease,
        opacity 0.15s ease;
}

.pjk3-footer-cta span {
    font-size: clamp(1rem, 2.5vw, 1.375rem);
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: var(--pjk3-tracking-heading);
    flex: 1;
    min-width: 0;
}

.pjk3-footer-cta-icon {
    font-size: 1.375rem;
    flex-shrink: 0;
    opacity: 0.95;
    transition: transform 0.2s ease;
}

.pjk3-footer-cta:hover,
.pjk3-footer-cta:focus {
    color: #fff !important;
    background: var(--maroon-dark);
    border-color: var(--maroon-dark);
    opacity: 0.95;
}

.pjk3-footer-cta:hover .pjk3-footer-cta-icon,
.pjk3-footer-cta:focus .pjk3-footer-cta-icon {
    transform: translate(4px, -3px);
}

.pjk3-footer-bar {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
}

@media (min-width: 768px) {
    .pjk3-footer-bar {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
}

.pjk3-footer-copy {
    font-size: 0.8125rem;
    color: var(--ink-muted);
}

.pjk3-footer-social {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.pjk3-footer-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    border: 1px solid var(--border);
    color: var(--ink-muted);
    text-decoration: none;
    font-size: 1.125rem;
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        color var(--pjk3-duration) var(--pjk3-ease-out),
        border-color var(--pjk3-duration) var(--pjk3-ease-out),
        background var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-footer-social a:hover {
    color: var(--maroon);
    border-color: var(--maroon-muted);
    background: var(--maroon-soft);
    transform: translateY(-3px);
}

.pjk3-footer-social a:first-child:hover {
    color: #fff;
    background: #25d366;
    border-color: #25d366;
}

/* Kontak */
.pjk3-contact-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.pjk3-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 0.65rem 0.75rem;
    margin: 0 -0.75rem;
    border-radius: var(--radius);
    transition:
        background var(--pjk3-duration) var(--pjk3-ease-out),
        transform var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-contact-item:hover {
    background: var(--maroon-soft);
    transform: translateX(4px);
}

.pjk3-contact-icon {
    flex-shrink: 0;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: var(--radius);
    background: var(--maroon-soft);
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        background var(--pjk3-duration) var(--pjk3-ease-out),
        color var(--pjk3-duration) var(--pjk3-ease-out);
    color: var(--maroon);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
}

.pjk3-contact-item:hover .pjk3-contact-icon {
    transform: scale(1.1);
    background: var(--maroon);
    color: #fff;
}

.pjk3-contact-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--ink-muted);
    margin-bottom: 0.2rem;
}

.pjk3-contact-item a {
    color: var(--maroon-dark);
    font-weight: 500;
    text-decoration: none;
}

.pjk3-contact-item a:hover {
    color: var(--maroon);
    text-decoration: underline;
}

.pjk3-contact-value {
    display: block;
    color: var(--ink);
    font-size: 0.9375rem;
    line-height: 1.5;
}

.pjk3-contact-form {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 2px);
    padding: 1.75rem;
}

@media (min-width: 992px) {
    .pjk3-contact-form {
        padding: 2rem 2.25rem;
    }
}

.pjk3-contact-form-head {
    margin-bottom: 1.5rem;
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--border);
}

.pjk3-contact-form-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--ink);
    margin: 0 0 0.35rem;
}

.pjk3-contact-form-desc {
    font-size: 0.875rem;
    color: var(--ink-muted);
    margin: 0;
    line-height: 1.5;
}

.pjk3-form-label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--ink);
    margin-bottom: 0.35rem;
}

.pjk3-form-control {
    border-color: var(--border);
    border-radius: var(--radius);
    padding: 0.625rem 0.875rem;
    font-size: 0.9375rem;
    background: var(--surface-elevated);
    transition:
        border-color var(--pjk3-duration-fast) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration-fast) var(--pjk3-ease-out);
}

.pjk3-form-control:hover {
    border-color: var(--maroon-muted);
}

.pjk3-form-control::placeholder {
    color: var(--placeholder);
}

.pjk3-form-control:focus {
    border-color: var(--maroon);
    box-shadow: 0 0 0 3px rgba(var(--maroon-rgb), 0.14);
}

.pjk3-form-hint {
    font-size: 0.75rem;
    color: var(--ink-muted);
    text-align: center;
}

.pjk3-contact-map-frame {
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 2px);
    overflow: hidden;
    background: var(--surface);
}

.pjk3-contact-map-frame iframe {
    display: block;
    width: 100%;
}

/* Section bands — selang-seling putih / abu */
.bg-light,
section.bg-light {
    background-color: var(--surface) !important;
}

.bg-white,
section.bg-white {
    background-color: var(--surface-elevated) !important;
}

/* Halaman layanan */
.pjk3-page-hero {
    padding-block: 2.5rem 2rem;
    background:
        radial-gradient(ellipse 70% 55% at 92% 8%, rgba(var(--maroon-rgb), 0.06) 0%, transparent 55%),
        radial-gradient(ellipse 40% 35% at 4% 92%, rgba(var(--green-rgb), 0.04) 0%, transparent 50%),
        var(--surface-elevated);
    border-bottom: 1px solid var(--border-soft);
}

@media (min-width: 992px) {
    .pjk3-page-hero {
        padding-block: 3rem 2.5rem;
    }
}

.pjk3-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    font-size: 0.8125rem;
    margin-bottom: 1.25rem;
    color: var(--ink-muted);
}

.pjk3-breadcrumb a {
    color: var(--ink-muted);
    text-decoration: none;
}

.pjk3-breadcrumb a:hover {
    color: var(--maroon);
}

.pjk3-breadcrumb-sep {
    opacity: 0.45;
}

.pjk3-breadcrumb [aria-current="page"] {
    color: var(--ink);
    font-weight: 500;
}

.pjk3-page-title {
    font-size: clamp(1.75rem, 3.5vw, 2.75rem);
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: var(--pjk3-tracking-heading);
    color: var(--ink);
}

.pjk3-page-lead {
    font-size: 1rem;
    line-height: 1.65;
    color: var(--ink-muted);
}

.pjk3-scope-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.pjk3-scope-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    font-weight: 500;
    color: var(--ink);
}

.pjk3-scope-list .ti {
    flex-shrink: 0;
    margin-top: 0.15rem;
}

.pjk3-service-media {
    border-color: var(--border) !important;
}

.pjk3-service-link-card {
    background: var(--surface-elevated);
    border-color: var(--border) !important;
    transition:
        transform var(--pjk3-duration) var(--pjk3-ease-out),
        border-color var(--pjk3-duration) var(--pjk3-ease-out),
        box-shadow var(--pjk3-duration) var(--pjk3-ease-out),
        background var(--pjk3-duration) var(--pjk3-ease-out);
}

.pjk3-service-link-card:hover {
    border-color: var(--maroon-muted) !important;
    background: var(--maroon-soft);
    box-shadow: var(--pjk3-shadow-hover);
    transform: translateY(-4px);
}

.pjk3-service-link-card:hover .text-dark {
    color: var(--maroon-dark) !important;
}

/* WA float */
.pjk3-wa-float {
    position: fixed;
    right: 1.25rem;
    bottom: 1.25rem;
    z-index: 1080;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    line-height: 1;
    text-decoration: none;
    transition: background 0.15s ease, box-shadow 0.12s ease, transform 0.12s ease;
    --btn-edge: #128c3a;
    --btn-edge-active: #0d6e32;
    --btn-highlight: rgba(255, 255, 255, 0.34);
    background: linear-gradient(180deg, #2ee07a 0%, #25d366 50%, #1aad55 100%);
    border: 1px solid #20b85c;
    box-shadow:
        inset 0 1px 0 var(--btn-highlight),
        0 var(--btn-3d-y) 0 var(--btn-edge);
}

.pjk3-wa-float .ti {
    font-size: 1.75rem;
    line-height: 1;
    filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.12));
}

.pjk3-wa-float:hover {
    color: #fff;
    background: linear-gradient(180deg, #2adb70 0%, #1fb355 50%, #18964a 100%);
    transform: translateY(-4px) scale(1.06);
    box-shadow: 0 10px 28px rgba(37, 211, 102, 0.45);
}

@media (prefers-reduced-motion: reduce) {
    .pjk3-marquee-track {
        animation: none;
    }

    .pjk3-wa-float {
        animation: none;
    }

    .pjk3-solution-card:hover .pjk3-solution-img,
    .pjk3-case-card:hover img {
        filter: none;
        transform: none;
    }
}

@media (min-width: 576px) {
    :root {
        --pjk3-gutter-x: 1.25rem;
    }
}

@media (min-width: 1200px) {
    :root {
        --pjk3-gutter-x: 1.5rem;
    }
}

@media (max-width: 991.98px) {
    section[id] {
        scroll-margin-top: 72px;
    }

    .pjk3-hero-top-inner {
        min-height: 0;
        justify-content: flex-start;
        padding-top: 1.5rem;
        padding-bottom: 1.25rem;
    }

    .pjk3-hero-title {
        font-size: clamp(1.625rem, 7vw, 2.25rem);
        line-height: 1.1;
        font-weight: 600;
    }

    .pjk3-hero-sub {
        font-size: 0.9375rem;
        line-height: 1.6;
    }

    .pjk3-hero-cta-group {
        margin-top: 1.25rem;
    }

    .pjk3-hero-cta-group .btn {
        min-height: 2.625rem;
    }

    .pjk3-trusted-label {
        font-size: 0.6875rem;
        letter-spacing: 0.14em;
        max-width: 100%;
        line-height: 1.45;
        padding-inline: 0.25rem;
    }

    .pjk3-partner-logo {
        height: 36px;
        padding-inline: 0.875rem;
    }

    .pjk3-marquee-track {
        gap: 1.25rem;
    }

    .pjk3-marquee-logos {
        width: 100vw;
        max-width: 100vw;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
    }

    .pjk3-marquee {
        mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
    }

    .pjk3-header .container-xl {
        padding-top: 0.75rem !important;
        padding-bottom: 0.75rem !important;
    }

    .pjk3-page-title {
        font-size: clamp(1.5rem, 6vw, 2rem);
    }

    .pjk3-section {
        padding-block: 2.5rem;
    }

    .pjk3-section--md {
        padding-block: 2rem;
    }

    .pjk3-faq-aside {
        position: static;
    }

    .pjk3-faq-item .accordion-body {
        padding: 0.875rem 1.25rem 1.25rem;
    }

    .pjk3-section-head .pjk3-section-title,
    .pjk3-section-head .col-lg-6,
    .pjk3-section-head .col-lg-7,
    .pjk3-section-head .col-lg-8 {
        max-width: 100%;
    }
}

@media (max-width: 575.98px) {
    :root {
        --pjk3-gutter-x: 1rem;
    }
}

html:has(body.pjk3-landing),
body.pjk3-landing {
    overflow-x: clip;
    max-width: 100%;
}

/* Tombol — hover Selia (pointer fine) */
@media (hover: hover) and (pointer: fine) {
    .btn-pjk3-primary:hover:not(:disabled),
    .btn-pjk3-outline:hover:not(:disabled),
    .btn-pjk3-wa:hover:not(:disabled),
    .btn-pjk3-green:hover:not(:disabled),
    .btn-pjk3-outline-green:hover:not(:disabled),
    .btn-accent-green:hover:not(:disabled),
    .btn-pjk3-light:hover:not(:disabled),
    .btn-pjk3-outline-light:hover:not(:disabled) {
        transform: translateY(-2px);
        filter: brightness(1.03);
    }

    .btn-pjk3-primary:hover:not(:disabled),
    .btn-pjk3-light:hover:not(:disabled),
    .btn-pjk3-outline-light:hover:not(:disabled) {
        box-shadow:
            inset 0 1px 0 var(--btn-highlight),
            0 calc(var(--btn-3d-y) + 1px) 0 var(--btn-edge, var(--btn-3d-edge)),
            0 8px 20px rgba(var(--maroon-rgb), 0.22);
    }

    .btn-pjk3-green:hover:not(:disabled),
    .btn-accent-green:hover:not(:disabled) {
        box-shadow:
            inset 0 1px 0 var(--btn-highlight),
            0 calc(var(--btn-3d-y) + 1px) 0 var(--btn-edge, var(--btn-3d-edge)),
            0 8px 20px rgba(var(--green-rgb), 0.28);
    }

    .btn-pjk3-outline-green:hover:not(:disabled) {
        box-shadow:
            inset 0 1px 0 var(--btn-highlight),
            0 calc(var(--btn-3d-y) + 1px) 0 var(--btn-edge, var(--btn-3d-edge)),
            0 6px 16px rgba(var(--green-rgb), 0.18);
    }

    .btn-pjk3-outline:hover:not(:disabled) {
        box-shadow:
            inset 0 1px 0 var(--btn-highlight),
            0 calc(var(--btn-3d-y) + 1px) 0 var(--btn-edge, var(--btn-3d-edge)),
            0 6px 16px rgba(45, 55, 72, 0.1);
    }

    .btn-pjk3-wa:hover:not(:disabled) {
        box-shadow:
            inset 0 1px 0 var(--btn-highlight),
            0 calc(var(--btn-3d-y) + 1px) 0 var(--btn-edge, var(--btn-3d-edge)),
            0 8px 22px rgba(37, 211, 102, 0.35);
    }

    .pjk3-theme-toggle:hover {
        transform: translateY(-1px);
    }

    .pjk3-breadcrumb a:hover {
        text-decoration: underline;
        text-underline-offset: 3px;
    }
}

/* Motion — entrance & scroll (PJK3) */
@keyframes pjk3-rise {
    from {
        opacity: 0;
        transform: translateY(16px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes pjk3-menu-in {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: no-preference) {
    .pjk3-hero-top-inner > .row {
        animation: pjk3-rise var(--pjk3-duration-slow) var(--pjk3-ease-out) 0.05s backwards;
    }

    .pjk3-hero-cta-group {
        animation: pjk3-rise var(--pjk3-duration-slow) var(--pjk3-ease-out) 0.14s backwards;
    }

    .pjk3-hero-img {
        animation: pjk3-rise 0.75s var(--pjk3-ease-out) 0.12s backwards;
    }

    .pjk3-page-hero .row {
        animation: pjk3-rise var(--pjk3-duration-slow) var(--pjk3-ease-out) 0.06s backwards;
    }

    .pjk3-mobile-menu.show .pjk3-mobile-nav > *.pjk3-menu-item-in {
        animation: pjk3-menu-in 0.42s var(--pjk3-ease-out) backwards;
        animation-delay: calc(0.03s * var(--pjk3-stagger, 0));
    }

    .pjk3-wa-float {
        transition: transform var(--pjk3-duration) var(--pjk3-ease-out), box-shadow var(--pjk3-duration) var(--pjk3-ease-out);
    }

    .pjk3-wa-float:hover {
        transform: translateY(-2px);
    }
}

/* Above-fold: tanpa scroll reveal */
#hero [data-aos],
.pjk3-page-hero [data-aos],
.pjk3-footer [data-aos] {
    opacity: 1 !important;
    transform: none !important;
}

/* Scroll reveal — smooth GPU transform */
body.pjk3-landing .pjk3-reveal {
    opacity: 0;
    transform: translate3d(0, 20px, 0);
    transition:
        opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--pjk3-reveal-delay, 0ms);
    will-change: transform, opacity;
    backface-visibility: hidden;
}

body.pjk3-landing .pjk3-reveal[data-aos='fade-left'] {
    transform: translate3d(20px, 0, 0);
}

body.pjk3-landing .pjk3-reveal[data-aos='fade-right'] {
    transform: translate3d(-20px, 0, 0);
}

body.pjk3-landing .pjk3-reveal[data-aos='fade'] {
    transform: none;
}

body.pjk3-landing .pjk3-reveal.is-revealed {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    will-change: auto;
}

@media (prefers-reduced-motion: reduce) {
    body.pjk3-landing .pjk3-reveal {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
        will-change: auto;
    }
}

/* Dark mode */
[data-theme="dark"] {
    color-scheme: dark;

    --maroon-rgb: 160, 52, 72;
    --maroon: #a0354f;
    --maroon-dark: #852b41;
    --maroon-soft: rgba(88, 20, 32, 0.35);
    --green-soft: rgba(28, 122, 71, 0.22);
    --green-muted: rgba(74, 155, 110, 0.4);

    --ink: #ffffff;
    --ink-muted: #b3b3b3;
    --border: #333333;
    --border-soft: #2a2a2a;
    --surface: #121212;
    --surface-elevated: #1e1e1e;
    --surface-card: #2a2a2a;

    --header-bg: rgba(18, 18, 18, 0.96);
    --hero-overlay: linear-gradient(135deg, rgba(18, 18, 18, 0.55) 0%, rgba(18, 18, 18, 0.8) 100%);
    --hero-fade-top: linear-gradient(180deg, #121212 0%, transparent 100%);
    --placeholder: #757575;

    --shadow-soft: 0 1px 0 rgba(255, 255, 255, 0.06), 0 4px 16px rgba(0, 0, 0, 0.5);
    --shadow-card: 0 0 0 1px rgba(255, 255, 255, 0.08), 0 8px 24px rgba(0, 0, 0, 0.45);
    --maroon-muted: rgba(176, 120, 136, 0.5);
    --pjk3-section-bg: #5a1012;
}

[data-theme="dark"] body.pjk3-landing {
    background: var(--surface);
}

[data-theme="dark"] .text-secondary {
    color: var(--ink-muted) !important;
}

[data-theme="dark"] .text-dark {
    color: var(--ink) !important;
}

[data-theme="dark"] .text-accent-maroon {
    color: #d9a0ad !important;
}

[data-theme="dark"] .text-accent-green {
    color: #7dd4a0 !important;
}

[data-theme="dark"] .pjk3-feature-card h3 {
    color: var(--ink);
}

[data-theme="dark"] .bg-white {
    background-color: var(--surface) !important;
}

[data-theme="dark"] .bg-light {
    background-color: var(--surface-elevated) !important;
}

[data-theme="dark"] .pjk3-logo-link {
    display: inline-flex;
    padding: 0.3rem 0.55rem;
    background: #fff;
    border-radius: 0.5rem;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] .offcanvas-header .pjk3-logo {
    padding: 0.25rem 0.45rem;
    background: #fff;
    border-radius: 0.5rem;
}

[data-theme="dark"] .pjk3-logo {
    filter: none;
    opacity: 1;
}

[data-theme="dark"] .pjk3-nav a,
[data-theme="dark"] .nav-link-dropdown {
    color: var(--ink-muted);
}

[data-theme="dark"] .pjk3-nav a:hover,
[data-theme="dark"] .nav-link-dropdown:hover,
[data-theme="dark"] .pjk3-nav a.is-active,
[data-theme="dark"] .pjk3-nav .nav-link-dropdown.is-active {
    color: #d9a0ad;
}

[data-theme="dark"] .pjk3-section-title {
    color: var(--ink);
}

[data-theme="dark"] .pjk3-eyebrow {
    color: #c88696;
}

[data-theme="dark"] .pjk3-header {
    border-color: var(--border) !important;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .dropdown-menu-pjk3 .dropdown-item.active {
    background: rgba(var(--maroon-rgb), 0.28);
    color: #fff;
}

[data-theme="dark"] .pjk3-mobile-nav a.is-active,
[data-theme="dark"] .pjk3-mobile-nav-toggle.is-active,
[data-theme="dark"] .pjk3-mobile-nav-sub a.is-active {
    color: #e8c4cc;
}

[data-theme="dark"] .offcanvas {
    background: var(--surface-elevated);
    border-color: var(--border);
}

[data-theme="dark"] .pjk3-hero {
    background: #121212;
}

[data-theme="dark"] .pjk3-hero-top {
    background:
        radial-gradient(ellipse 75% 55% at 100% 0%, rgba(217, 160, 173, 0.1) 0%, transparent 58%),
        #121212;
    border-bottom-color: var(--border-soft);
}

[data-theme="dark"] .pjk3-hero-title {
    color: #ffffff;
}

[data-theme="dark"] .pjk3-hero-sub {
    color: var(--ink-muted);
}

[data-theme="dark"] .pjk3-hero-industries {
    background: var(--surface);
}

[data-theme="dark"] .pjk3-page-hero {
    background:
        radial-gradient(ellipse 70% 55% at 92% 8%, rgba(217, 160, 173, 0.08) 0%, transparent 55%),
        #121212;
    border-color: var(--border-soft);
}

[data-theme="dark"] .pjk3-page-title {
    color: #fff;
}

[data-theme="dark"] .pjk3-breadcrumb [aria-current="page"] {
    color: #e0e0e0;
}

[data-theme="dark"] .pjk3-service-link-card {
    background: var(--surface-card);
    border-color: var(--border) !important;
}

[data-theme="dark"] .pjk3-service-link-card:hover {
    background: rgba(var(--maroon-rgb), 0.12);
    border-color: rgba(var(--maroon-rgb), 0.4) !important;
}

[data-theme="dark"] .pjk3-service-link-card:hover .text-dark {
    color: #fce8ee !important;
}

/* Dark mode — gradasi tombol Selia */
[data-theme="dark"] .btn-pjk3-primary {
    --btn-edge: #8a2830;
    --btn-edge-active: #5c1013;
    background: linear-gradient(180deg, #c83845 0%, var(--maroon) 48%, var(--maroon-dark) 100%);
    border-color: #a32e38;
}

[data-theme="dark"] .btn-pjk3-primary:hover,
[data-theme="dark"] .btn-pjk3-primary:focus {
    background: linear-gradient(180deg, #b8303d 0%, var(--maroon-dark) 48%, #4d0a0d 100%);
    border-color: #8a2530;
}

[data-theme="dark"] .btn-pjk3-green,
[data-theme="dark"] .btn-accent-green {
    --btn-edge: #1a5c38;
    --btn-edge-active: #124a2d;
    background: linear-gradient(180deg, #3aab6a 0%, var(--green) 48%, var(--green-dark) 100%);
    border-color: #2a8f55;
}

[data-theme="dark"] .btn-pjk3-green:hover,
[data-theme="dark"] .btn-pjk3-green:focus,
[data-theme="dark"] .btn-accent-green:hover,
[data-theme="dark"] .btn-accent-green:focus {
    background: linear-gradient(180deg, #45b874 0%, var(--green-dark) 48%, #124a2d 100%);
    border-color: #248f56;
}

[data-theme="dark"] .btn-pjk3-outline {
    --btn-edge: var(--btn-3d-edge);
    --btn-edge-active: #1a1a1a;
    background: linear-gradient(180deg, #343434 0%, var(--surface-elevated) 52%, #181818 100%);
    border-color: #404040;
}

[data-theme="dark"] .btn-pjk3-outline:hover,
[data-theme="dark"] .btn-pjk3-outline:focus {
    background: linear-gradient(180deg, #3a2a2e 0%, rgba(88, 20, 32, 0.45) 55%, #24181c 100%);
    border-color: rgba(160, 52, 72, 0.55);
    color: #e8c4cc;
}

[data-theme="dark"] .pjk3-hero-top .btn-pjk3-outline {
    background: linear-gradient(180deg, #2e2e2e 0%, #1e1e1e 55%, #141414 100%);
    border-color: #4a4a4a;
    color: #e0e0e0;
}

[data-theme="dark"] .pjk3-hero-top .btn-pjk3-outline:hover {
    background: linear-gradient(180deg, #3a3a3a 0%, #2a2a2a 55%, #1a1a1a 100%);
    border-color: #757575;
    color: #fff;
}

[data-theme="dark"] .btn-pjk3-outline-green {
    background: linear-gradient(180deg, #2a3230 0%, var(--surface-elevated) 52%, #141a17 100%);
    color: #7dd4a0;
    border-color: rgba(28, 122, 71, 0.45);
}

[data-theme="dark"] .btn-pjk3-outline-green:hover,
[data-theme="dark"] .btn-pjk3-outline-green:focus {
    background: linear-gradient(180deg, #2e4036 0%, var(--green-soft) 55%, #1a2820 100%);
    color: #b8f0cc;
}

[data-theme="dark"] .pjk3-wa-float {
    animation: none;
}

[data-theme="dark"] .pjk3-solutions .pjk3-swiper-btn,
[data-theme="dark"] .pjk3-swiper-btn {
    background: #fff;
    color: var(--maroon-dark);
}

[data-theme="dark"] .pjk3-solutions .pjk3-swiper-btn:hover,
[data-theme="dark"] .pjk3-swiper-btn:hover {
    background: #f0e8ea;
    color: var(--maroon);
}

[data-theme="dark"] .pjk3-cta .btn-pjk3-outline-light {
    border-color: rgba(255, 255, 255, 0.85);
    color: #fff;
}

[data-theme="dark"] .pjk3-cta .btn-pjk3-outline-light:hover {
    background: rgba(255, 255, 255, 0.18);
    border-color: #fff;
    color: #fff;
}

[data-theme="dark"] .pjk3-stat-card {
    filter: brightness(0.75) saturate(0.85);
}

[data-theme="dark"] .pjk3-stat-num {
    color: #d9a0ad;
}

[data-theme="dark"] .pjk3-stat-label {
    background: var(--surface-card);
    color: var(--ink-muted);
}

[data-theme="dark"] .pjk3-badge {
    background: var(--surface-card);
    border-color: var(--border);
    color: var(--ink-muted);
}

[data-theme="dark"] .pjk3-badge:hover {
    border-color: rgba(var(--maroon-rgb), 0.5);
    background: var(--maroon-soft);
    color: #e8c4cc;
}

[data-theme="dark"] .pjk3-partner-logo {
    filter: brightness(1.2) contrast(0.9);
}

[data-theme="dark"] .pjk3-feature-num {
    color: #e8b4c0;
    opacity: 0.55;
}

[data-theme="dark"] .pjk3-feature-icon.is-maroon {
    background: rgba(var(--maroon-rgb), 0.22);
    color: #e8b4c0;
}

[data-theme="dark"] .pjk3-feature-icon.is-green {
    background: rgba(28, 122, 71, 0.22);
    color: #7dd4a0;
}

[data-theme="dark"] .pjk3-feature-card {
    background: var(--surface-card) !important;
    border-color: var(--border) !important;
    box-shadow: var(--shadow-card);
}

@media (hover: hover) and (pointer: fine) {
    [data-theme="dark"] .pjk3-feature-card:hover {
        background: linear-gradient(
            165deg,
            rgba(var(--maroon-rgb), 0.22) 0%,
            var(--surface-card) 52%
        ) !important;
        border-color: rgba(var(--maroon-rgb), 0.55) !important;
        box-shadow:
            0 14px 32px rgba(0, 0, 0, 0.55),
            inset 0 1px 0 rgba(255, 255, 255, 0.07),
            0 0 0 1px rgba(var(--maroon-rgb), 0.28);
        transform: translateY(-4px);
    }

    [data-theme="dark"] .pjk3-feature-card--row:hover {
        transform: none;
        background: var(--surface-card) !important;
        box-shadow: 0 10px 28px rgba(0, 0, 0, 0.4);
    }

    [data-theme="dark"] .pjk3-feature-card:hover .pjk3-feature-icon.is-maroon {
        background: var(--maroon);
        color: #fff;
        box-shadow: 0 8px 24px rgba(var(--maroon-rgb), 0.45);
    }

    [data-theme="dark"] .pjk3-feature-card:hover .pjk3-feature-icon.is-green {
        background: var(--green-dark);
        color: #fff;
        box-shadow: 0 8px 24px rgba(28, 122, 71, 0.4);
    }

    [data-theme="dark"] .pjk3-feature-card:hover .pjk3-feature-icon .ti {
        transform: scale(1.08);
    }

    [data-theme="dark"] .pjk3-feature-card:hover h3 {
        color: #fff;
    }

    [data-theme="dark"] .pjk3-feature-card:hover .text-secondary {
        color: #c8c8c8 !important;
    }
}

[data-theme="dark"] .pjk3-case-card {
    box-shadow: var(--shadow-card);
    border: 1px solid var(--border);
}

[data-theme="dark"] .pjk3-case-overlay {
    background: linear-gradient(to top, rgba(18, 18, 18, 0.94) 0%, rgba(18, 18, 18, 0.4) 55%, transparent 100%);
}

[data-theme="dark"] .pjk3-flow {
    background: var(--surface-elevated);
}

[data-theme="dark"] .pjk3-flow-title {
    color: var(--ink);
}

[data-theme="dark"] .pjk3-testi-card {
    background: var(--surface-card);
    border-color: var(--border);
    box-shadow: var(--shadow-card);
}

[data-theme="dark"] .pjk3-testi-foot {
    background: var(--surface);
}

@media (hover: hover) and (pointer: fine) {
    [data-theme="dark"] .pjk3-testi-swiper .pjk3-testi-card:hover {
        border-color: rgba(var(--maroon-rgb), 0.45);
        box-shadow: 0 10px 28px rgba(0, 0, 0, 0.35);
    }
}

[data-theme="dark"] .pjk3-testi-pagination .swiper-pagination-bullet {
    background: var(--border) !important;
}

[data-theme="dark"] .pjk3-testi-pagination .swiper-pagination-bullet-active {
    background: var(--maroon) !important;
}

[data-theme="dark"] .pjk3-faq-aside {
    background: var(--surface-elevated);
    border-color: var(--border);
    box-shadow: var(--shadow-card);
}

[data-theme="dark"] .pjk3-faq-aside-icon {
    background: rgba(var(--maroon-rgb), 0.22);
    color: #e8b4c0;
}

[data-theme="dark"] .pjk3-faq-item {
    background: var(--surface-elevated);
    border-color: var(--border) !important;
}

[data-theme="dark"] .pjk3-faq-item .accordion-button {
    background: var(--surface-elevated);
}

[data-theme="dark"] .pjk3-faq-num {
    color: #e8b4c0;
}

[data-theme="dark"] .pjk3-faq-item .accordion-body {
    background: var(--surface-elevated);
    border-top: 0;
}

[data-theme="dark"] .pjk3-faq-list .accordion-button::after {
    --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23e8b4c0'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23e8b4c0'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
    filter: none;
}

[data-theme="dark"] .pjk3-accordion .accordion-item {
    background: var(--surface-elevated) !important;
    border-color: var(--border) !important;
}

[data-theme="dark"] .pjk3-accordion .accordion-button {
    background: var(--surface-elevated);
    color: var(--ink);
    box-shadow: none;
}

[data-theme="dark"] .pjk3-accordion .accordion-button:not(.collapsed) {
    background: rgba(var(--maroon-rgb), 0.14);
    color: #e8c4cc;
}

[data-theme="dark"] .pjk3-accordion .accordion-button::after {
    filter: brightness(2);
}

[data-theme="dark"] .pjk3-accordion .accordion-body {
    background: var(--surface-elevated);
    color: var(--ink-muted);
}

[data-theme="dark"] .pjk3-contact-form {
    background: var(--surface);
    border-color: var(--border);
}

[data-theme="dark"] .pjk3-contact-form-head {
    border-color: var(--border);
}

[data-theme="dark"] .pjk3-form-control,
[data-theme="dark"] .pjk3-contact-form .form-select {
    background: var(--surface-elevated);
    border-color: var(--border);
    color: var(--ink);
}

[data-theme="dark"] .pjk3-contact-map-frame {
    background: var(--surface);
    border-color: var(--border);
}

[data-theme="dark"] .pjk3-contact-map-frame iframe {
    filter: brightness(0.82) contrast(1.05) saturate(0.85);
}

[data-theme="dark"] .pjk3-contact-icon {
    background: rgba(var(--maroon-rgb), 0.16);
    color: #d9a0ad;
}

[data-theme="dark"] .pjk3-contact-item a {
    color: #d9a0ad;
}

[data-theme="dark"] .pjk3-contact-item a:hover {
    color: #e8c4cc;
}

[data-theme="dark"] .pjk3-logo-link {
    background: #fff;
}

[data-theme="dark"] .dropdown-menu-pjk3 {
    background: var(--surface-elevated);
    border: 1px solid var(--border) !important;
}

[data-theme="dark"] .dropdown-menu-pjk3 .dropdown-item {
    color: var(--ink-muted);
}

[data-theme="dark"] .dropdown-menu-pjk3 .dropdown-item:hover {
    background: rgba(var(--maroon-rgb), 0.14);
    color: #e8c4cc;
}

[data-theme="dark"] .pjk3-trusted-label {
    color: var(--ink-muted);
}

[data-theme="dark"] .pjk3-industry-chip {
    background: var(--surface-card);
    border-color: var(--border);
    color: var(--ink-muted);
}

[data-theme="dark"] .pjk3-mobile-nav a,
[data-theme="dark"] .pjk3-mobile-nav-toggle {
    color: var(--ink-muted);
    border-color: var(--border-soft);
}

[data-theme="dark"] .pjk3-mobile-nav-toggle:hover,
[data-theme="dark"] .pjk3-mobile-nav-toggle:focus,
[data-theme="dark"] .pjk3-mobile-nav-toggle[aria-expanded="true"] {
    color: #e8c4cc;
}

[data-theme="dark"] .pjk3-mobile-nav-group {
    border-color: var(--border);
}

[data-theme="dark"] .pjk3-mobile-nav .btn-pjk3-outline.pjk3-theme-toggle {
    color: var(--ink) !important;
}

[data-theme="dark"] .pjk3-footer-cta {
    background: var(--maroon);
    border-color: var(--maroon);
}

[data-theme="dark"] .pjk3-footer-cta:hover,
[data-theme="dark"] .pjk3-footer-cta:focus {
    background: var(--maroon-dark);
    border-color: var(--maroon-dark);
}

[data-theme="dark"] ::selection {
    background: rgba(var(--maroon-rgb), 0.45);
    color: var(--ink);
}

[data-theme="dark"] .pjk3-theme-toggle {
    flex-shrink: 0;
}

/* 404 */
.pjk3-error-body {
    padding-block: clamp(2.5rem, 6vw, 4rem);
}

.pjk3-error-panel {
    max-width: 40rem;
}

.pjk3-error-code {
    margin: 0 0 1rem;
    font-family: var(--font-heading);
    font-size: clamp(4.5rem, 14vw, 7rem);
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.05em;
    color: var(--maroon);
    opacity: 0.18;
}

.pjk3-error-text {
    font-size: 1rem;
    line-height: 1.7;
}

[data-theme="dark"] .pjk3-error-code {
    color: #d9a0ad;
    opacity: 0.35;
}
