/* PT LIP V11 Alternative — premium soft dark editorial layout */
:root {
    --red: #8B0A1A;
    --red-dark: #4E0710;
    --red-deep: #26070B;
    --gold: #C9973B;
    --gold-light: #E4BD6A;
    --ink: #170C0E;
    --ink-2: #281114;
    --cream: #FBF7F0;
    --cream-2: #F1E7D8;
    --paper: #FFFDF8;
    --muted: #766266;
    --soft: #A08A85;
    --line: rgba(91, 22, 29, .13);
    --line-dark: rgba(255, 255, 255, .13);
    --glow: rgba(201, 151, 59, .18);
    --font-display: 'Cormorant Garamond', Georgia, serif;
    --font-body: 'DM Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --color-red: var(--red);
    --color-maroon: var(--red-dark);
    --color-gold: var(--gold);
    --color-gold-light: var(--gold-light);
    --color-off-white: var(--cream);
    --color-white: var(--paper);
    --color-text: var(--ink);
    --color-text-mid: var(--muted);
    --color-text-muted: var(--soft);
    --color-border: var(--line);
    --color-border-mid: rgba(91, 22, 29, .24);
    --color-surface: var(--cream-2);
    --container: 1180px;
    --wide: 1340px;
    --pad: clamp(18px, 2.4vw, 34px);
    --radius-xl: 34px;
    --radius-lg: 26px;
    --radius: 18px;
    --shadow: 0 24px 80px rgba(31, 8, 12, .14);
    --shadow-soft: 0 12px 38px rgba(31, 8, 12, .09);
}

html { scroll-behavior: smooth; background: var(--cream); }
body {
    background:
        radial-gradient(circle at 12% 0%, rgba(201, 151, 59, .12), transparent 34rem),
        linear-gradient(180deg, #1E080C 0, #2A0A10 420px, var(--cream) 421px);
    color: var(--ink);
    font-family: var(--font-body);
    min-height: 100vh;
}
body.v11-page { background: var(--cream); }
body.nav-open { overflow: hidden; }
a { text-underline-offset: 4px; }
.container, .footer-inner { width: min(var(--container), calc(100% - 34px)); max-width: var(--container); }
@media (min-width: 1480px) { .container, .footer-inner { width: min(var(--wide), calc(100% - 72px)); max-width: var(--wide); } }
.section { padding: clamp(72px, 8vw, 118px) 0; }
.section-label, .v11-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--gold);
    font-size: .72rem;
    font-weight: 800;
    letter-spacing: .15em;
    text-transform: uppercase;
    line-height: 1.4;
}
.section-label::before, .v11-kicker span {
    content: '';
    width: 28px;
    height: 1px;
    background: currentColor;
    display: inline-block;
}
.section-title {
    margin: 12px 0 0;
    font-family: var(--font-display);
    font-size: clamp(2.05rem, 4.8vw, 4.6rem);
    line-height: .95;
    letter-spacing: -.035em;
    color: var(--ink);
    max-width: 820px;
}
.section-sub, .v11-lead, .v11-body-large {
    margin: 20px 0 0;
    max-width: 720px;
    color: var(--muted);
    font-size: clamp(.98rem, 1.2vw, 1.08rem);
    line-height: 1.9;
    font-weight: 500;
}
.v11-section-head { max-width: 880px; }
.v11-section-light { background: var(--cream); }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mt-32 { margin-top: 32px; }
.mt-48 { margin-top: 48px; }

/* Header */
.site-header.v11-header { padding: 18px var(--pad); }
.v11-nav {
    min-height: 72px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 24px;
    background: rgba(31, 9, 13, .74);
    box-shadow: 0 20px 64px rgba(0, 0, 0, .22);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}
.site-header.scrolled .v11-nav {
    background: rgba(38, 7, 11, .92);
    border-color: rgba(228, 189, 106, .20);
}
.v11-brand-mark {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border-radius: 18px;
    background: linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.03));
    border: 1px solid rgba(255,255,255,.13);
}
.v11-brand-mark img, .nav-logo-img { width: 42px; height: 42px; object-fit: contain; border-radius: 0; }
.v11-nav .nav-brand-name { color: var(--paper); font-size: clamp(1rem, 1.1vw, 1.22rem); }
.v11-nav .nav-brand-sub { color: rgba(255,255,255,.56); }
.v11-nav .nav-link { color: rgba(255,255,255,.72); }
.v11-nav .nav-link:hover, .v11-nav .nav-link.active { color: var(--paper); background: rgba(255,255,255,.10); }
.v11-nav .nav-link-cta {
    color: #241005;
    background: linear-gradient(135deg, var(--gold-light), var(--gold));
    box-shadow: 0 12px 28px rgba(201,151,59,.22);
}
.v11-nav .nav-link-cta:hover { color: #241005; transform: translateY(-1px); }
.v11-nav .toggle-bar { background: var(--paper); }

/* Buttons */
.btn, .form-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 48px;
    border-radius: 999px;
    padding: 13px 22px;
    border: 1px solid transparent;
    text-decoration: none;
    font-size: .85rem;
    font-weight: 800;
    letter-spacing: .03em;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
    cursor: pointer;
}
.btn:hover, .form-submit:hover { transform: translateY(-2px); }
.btn-primary, .form-submit {
    color: #271106;
    background: linear-gradient(135deg, var(--gold-light), var(--gold));
    box-shadow: 0 14px 38px rgba(201,151,59,.24);
}
.btn-outline {
    color: var(--paper);
    border-color: rgba(255,255,255,.22);
    background: rgba(255,255,255,.08);
}
.v11-section-light .btn-outline, .v11-page-hero .btn-outline, .v11-detail-side .btn-outline, .v11-profile-card .btn-outline {
    color: var(--red-dark);
    border-color: rgba(91, 22, 29, .22);
    background: rgba(255,255,255,.58);
}
.form-submit { width: 100%; border: 0; }
.form-submit[disabled] { opacity: .72; cursor: not-allowed; transform: none; }
.v11-text-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--gold);
    font-weight: 800;
    text-decoration: none;
}
.v11-text-link:hover { color: var(--gold-light); }

/* Hero */
.v11-hero {
    position: relative;
    overflow: hidden;
    min-height: 760px;
    padding: clamp(150px, 15vw, 210px) 0 clamp(72px, 9vw, 130px);
    color: var(--paper);
    background:
        linear-gradient(120deg, rgba(18, 5, 8, .96), rgba(66, 8, 16, .88)),
        radial-gradient(circle at 80% 20%, rgba(201, 151, 59, .26), transparent 34rem),
        #23070B;
}
.v11-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: .36;
    background-image: linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
    background-size: 62px 62px;
    mask-image: linear-gradient(180deg, black, transparent 90%);
}
.v11-orb { position: absolute; border-radius: 999px; filter: blur(10px); pointer-events: none; }
.v11-orb-a { width: 360px; height: 360px; right: -120px; top: 120px; background: radial-gradient(circle, rgba(201,151,59,.34), transparent 70%); }
.v11-orb-b { width: 280px; height: 280px; left: -80px; bottom: 10%; background: radial-gradient(circle, rgba(139,10,26,.36), transparent 70%); }
.v11-hero-grid { position: relative; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(320px, .72fr); gap: clamp(36px, 7vw, 96px); align-items: center; }
.v11-hero-copy h1 {
    margin: 18px 0 0;
    max-width: 850px;
    font-family: var(--font-display);
    font-size: clamp(3.2rem, 7.4vw, 7.6rem);
    line-height: .86;
    letter-spacing: -.055em;
    font-weight: 700;
    color: var(--paper);
}
.v11-hero-copy .v11-lead { color: rgba(255,255,255,.74); max-width: 690px; }
.v11-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.v11-hero-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: 660px;
    gap: 1px;
    margin-top: 42px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 22px;
    background: rgba(255,255,255,.08);
}
.v11-hero-stats div { padding: 20px; background: rgba(255,255,255,.045); }
.v11-hero-stats strong { display: block; font-family: var(--font-display); color: var(--gold-light); font-size: clamp(2rem, 4vw, 3.4rem); line-height: .9; }
.v11-hero-stats span { display: block; margin-top: 8px; color: rgba(255,255,255,.62); font-size: .75rem; text-transform: uppercase; letter-spacing: .13em; }
.v11-command-card, .v11-profile-card, .v11-side-panel, .v11-contact-form {
    border: 1px solid rgba(255,255,255,.13);
    border-radius: var(--radius-xl);
    background: linear-gradient(160deg, rgba(255,255,255,.13), rgba(255,255,255,.045));
    box-shadow: 0 30px 90px rgba(0,0,0,.24);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}
.v11-command-card { padding: clamp(24px, 3vw, 34px); color: var(--paper); }
.v11-card-top { display: flex; align-items: center; gap: 18px; padding-bottom: 24px; border-bottom: 1px solid rgba(255,255,255,.12); }
.v11-card-top img, .v11-profile-card img { width: 104px; height: 104px; object-fit: contain; }
.v11-card-top span { display: block; color: rgba(255,255,255,.52); font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 800; }
.v11-card-top h2, .v11-profile-card h2, .v11-side-panel h2, .v11-contact-form h2 { margin: 4px 0 0; font-family: var(--font-display); line-height: 1; letter-spacing: -.03em; font-size: clamp(1.8rem, 2.8vw, 2.65rem); }
.v11-signal-list { display: grid; gap: 12px; margin: 24px 0; }
.v11-signal-list div { display: grid; gap: 6px; padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,.11); }
.v11-signal-list span { color: rgba(255,255,255,.52); font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 800; }
.v11-signal-list strong { color: var(--paper); font-size: .94rem; line-height: 1.55; }

/* Strip */
.v11-strip { margin-top: -1px; background: var(--ink); color: var(--paper); padding: 0 0 36px; }
.v11-strip-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 26px;
    overflow: hidden;
    background: rgba(255,255,255,.08);
}
.v11-strip-grid div { padding: 26px; background: rgba(255,255,255,.045); }
.v11-strip-grid span { color: var(--gold-light); font-family: var(--font-display); font-size: 1.5rem; }
.v11-strip-grid strong { display: block; margin-top: 8px; font-size: 1.05rem; color: var(--paper); }
.v11-strip-grid p { margin: 8px 0 0; color: rgba(255,255,255,.62); font-size: .9rem; line-height: 1.75; }

/* Service cards */
.v11-service-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 16px; }
.v11-service-card {
    position: relative;
    min-height: 320px;
    display: flex;
    flex-direction: column;
    padding: 24px;
    border: 1px solid var(--line);
    border-radius: 28px;
    background: var(--paper);
    color: var(--ink);
    text-decoration: none;
    box-shadow: var(--shadow-soft);
    overflow: hidden;
}
.v11-service-card::after {
    content: '';
    position: absolute;
    inset: auto -40px -70px auto;
    width: 160px;
    height: 160px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(139,10,26,.14), transparent 70%);
}
.v11-service-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: rgba(139,10,26,.28); }
.v11-service-index { color: var(--gold); font-family: var(--font-display); font-size: 1.55rem; line-height: 1; }
.v11-service-card h3 { margin: 26px 0 0; font-family: var(--font-display); font-size: 1.7rem; line-height: 1; letter-spacing: -.025em; color: var(--ink); }
.v11-service-card p { margin: 14px 0 0; color: var(--muted); font-size: .9rem; line-height: 1.7; }
.v11-chip-row { display: flex; flex-wrap: wrap; gap: 8px; }
.v11-service-card .v11-chip-row { margin-top: auto; padding-top: 22px; }
.v11-chip-row span, .v11-chip-row em {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(139,10,26,.13);
    color: var(--red-dark);
    background: rgba(139,10,26,.055);
    font-style: normal;
    font-size: .72rem;
    font-weight: 800;
}
.v11-service-card em { margin-top: 18px; color: var(--red); font-style: normal; font-weight: 800; font-size: .82rem; }

/* Dark section */
.v11-dark-panel {
    background:
        radial-gradient(circle at 85% 10%, rgba(201,151,59,.18), transparent 26rem),
        linear-gradient(135deg, #21070B, #3A0811 62%, #170507);
    color: var(--paper);
}
.v11-dark-panel .section-title { color: var(--paper); }
.v11-dark-panel .section-sub { color: rgba(255,255,255,.70); }
.v11-process-grid { display: grid; grid-template-columns: minmax(0, .92fr) minmax(320px, .78fr); gap: clamp(34px, 6vw, 84px); align-items: start; }
.v11-process-list { display: grid; gap: 14px; }
.v11-process-list article {
    display: grid;
    grid-template-columns: 64px 1fr;
    gap: 18px;
    padding: 22px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 24px;
    background: rgba(255,255,255,.065);
}
.v11-process-list span {
    width: 48px;
    height: 48px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    color: #261007;
    background: var(--gold-light);
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.2rem;
}
.v11-process-list h3 { margin: 0; color: var(--paper); font-size: 1.05rem; }
.v11-process-list p { margin: 6px 0 0; color: rgba(255,255,255,.66); line-height: 1.7; font-size: .9rem; }

/* Legal split */
.v11-legal-split { display: grid; grid-template-columns: minmax(0, .85fr) minmax(320px, 1fr); gap: clamp(32px, 6vw, 78px); align-items: start; }
.v11-kbli-wall { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.v11-kbli-wall div, .v11-post-card, .v11-directory-card, .v11-kbli-card, .v11-value-grid div, .v11-benefit-grid div, .v11-check-grid span, .v11-map-card {
    border: 1px solid var(--line);
    border-radius: 24px;
    background: var(--paper);
    box-shadow: var(--shadow-soft);
}
.v11-kbli-wall div { padding: 22px; }
.v11-kbli-wall strong { display: block; font-family: var(--font-display); font-size: 1.4rem; line-height: 1; color: var(--ink); }
.v11-kbli-wall p { margin: 10px 0 0; color: var(--muted); font-size: .9rem; }

/* Posts and CTA */
.v11-post-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.v11-post-card { display: block; min-height: 210px; padding: 24px; color: var(--ink); text-decoration: none; }
.v11-post-card span { color: var(--gold); font-size: .72rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.v11-post-card h3 { margin: 16px 0 0; font-family: var(--font-display); font-size: 1.7rem; line-height: 1; }
.v11-post-card p { color: var(--muted); line-height: 1.7; }
.v11-cta-band {
    padding: clamp(54px, 7vw, 92px) 0;
    background: linear-gradient(135deg, #2B080E, #590B17 58%, #7E1021);
    color: var(--paper);
}
.v11-cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 26px; }
.v11-cta-inner h2 { margin: 8px 0 0; max-width: 760px; font-family: var(--font-display); font-size: clamp(2rem, 4.2vw, 4rem); line-height: .98; letter-spacing: -.03em; }
.v11-cta-inner p:not(.section-label) { margin: 14px 0 0; color: rgba(255,255,255,.68); max-width: 680px; }

/* Page hero */
.v11-page-hero {
    padding: clamp(150px, 15vw, 190px) 0 clamp(64px, 8vw, 100px);
    color: var(--paper);
    background:
        radial-gradient(circle at 84% 20%, rgba(201,151,59,.19), transparent 28rem),
        linear-gradient(135deg, #1A0508, #3B0811 68%, #24070B);
}
.v11-page-hero h1 {
    margin: 14px 0 0;
    max-width: 930px;
    font-family: var(--font-display);
    font-size: clamp(3rem, 6.5vw, 6.5rem);
    line-height: .88;
    letter-spacing: -.055em;
    color: var(--paper);
}
.v11-page-hero p:not(.section-label):not(.breadcrumb *) {
    max-width: 720px;
    margin: 20px 0 0;
    color: rgba(255,255,255,.72);
    font-size: 1.05rem;
    line-height: 1.85;
}
.breadcrumb { color: rgba(255,255,255,.56); }
.breadcrumb a { color: rgba(255,255,255,.72); text-decoration: none; }
.breadcrumb span, .breadcrumb .separator { color: rgba(255,255,255,.40); }

/* Directory */
.v11-directory-grid { display: grid; gap: 18px; }
.v11-directory-card { padding: clamp(24px, 3vw, 34px); }
.v11-directory-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; }
.v11-directory-head > span { color: var(--gold); font-family: var(--font-display); font-size: 2.8rem; line-height: .8; }
.v11-directory-card h2 { margin: 20px 0 0; font-family: var(--font-display); font-size: clamp(2rem, 4vw, 4rem); line-height: .94; letter-spacing: -.04em; color: var(--ink); }
.v11-directory-card p { margin: 16px 0 0; color: var(--muted); line-height: 1.85; max-width: 940px; }
.v11-mini-list { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.v11-mini-list span { display: inline-flex; padding: 10px 13px; border-radius: 999px; background: rgba(139,10,26,.06); color: var(--red-dark); font-size: .78rem; font-weight: 800; }
.v11-card-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }

/* Detail */
.v11-detail-grid { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: clamp(28px, 5vw, 70px); align-items: start; }
.v11-detail-main { min-width: 0; }
.v11-content-block { margin-top: 46px; }
.v11-content-block h2 { margin: 0 0 18px; font-family: var(--font-display); font-size: clamp(2rem, 3.6vw, 3.5rem); line-height: .98; letter-spacing: -.03em; }
.v11-check-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.v11-check-grid span { position: relative; display: block; padding: 18px 18px 18px 48px; line-height: 1.65; color: var(--ink); font-weight: 700; }
.v11-check-grid span::before { content: ''; position: absolute; left: 20px; top: 24px; width: 8px; height: 8px; border-radius: 50%; background: var(--gold); }
.v11-timeline { display: grid; gap: 12px; }
.v11-time-item { display: grid; grid-template-columns: 64px 1fr; gap: 18px; padding: 22px; border: 1px solid var(--line); border-radius: 26px; background: var(--paper); }
.v11-time-item > span { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 16px; background: var(--red-dark); color: var(--gold-light); font-family: var(--font-display); font-size: 1.25rem; }
.v11-time-item h3 { margin: 0; font-size: 1rem; color: var(--ink); }
.v11-time-item p { margin: 8px 0 0; color: var(--muted); line-height: 1.75; }
.v11-benefit-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.v11-benefit-grid div { padding: 20px; color: var(--ink); line-height: 1.7; font-weight: 700; }
.v11-detail-side { position: sticky; top: 110px; display: grid; gap: 16px; }
.v11-side-panel { padding: 26px; color: var(--ink); background: var(--paper); border-color: var(--line); box-shadow: var(--shadow-soft); }
.v11-side-panel h2 { color: var(--ink); }
.v11-side-panel p { color: var(--muted); line-height: 1.75; }
.v11-side-links { display: grid; gap: 1px; border: 1px solid var(--line); border-radius: 20px; overflow: hidden; }
.v11-side-links a { display: flex; justify-content: space-between; gap: 14px; padding: 14px; background: rgba(139,10,26,.035); color: var(--ink); text-decoration: none; font-size: .88rem; font-weight: 800; }
.v11-side-links a:hover { background: rgba(139,10,26,.08); }

/* Cara kerja */
.v11-workspace { border: 1px solid var(--line); border-radius: 32px; background: var(--paper); box-shadow: var(--shadow-soft); overflow: hidden; }
.v11-tabs { display: flex; overflow-x: auto; gap: 0; padding: 14px; border-bottom: 1px solid var(--line); background: #F8EFE3; }
.v11-tabs .carakerja-tab {
    flex: 0 0 auto;
    border: 0;
    border-radius: 999px;
    padding: 12px 16px;
    color: var(--muted);
    background: transparent;
    font-weight: 800;
    cursor: pointer;
}
.v11-tabs .carakerja-tab.active { color: var(--paper); background: var(--red-dark); }
.carakerja-content { display: none; padding: clamp(22px, 3vw, 34px); }
.carakerja-content.active { display: block; }
.v11-work-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; margin-bottom: 24px; }
.v11-work-head h2 { margin: 8px 0 0; font-family: var(--font-display); font-size: clamp(2rem, 4vw, 4rem); line-height: .94; }
.v11-process-cards { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.v11-process-cards article { padding: 22px; border-radius: 24px; border: 1px solid var(--line); background: linear-gradient(180deg, #fff, #FBF4EA); }
.v11-process-cards span { color: var(--gold); font-family: var(--font-display); font-size: 2rem; }
.v11-process-cards h3 { margin: 22px 0 0; font-size: 1rem; color: var(--ink); }
.v11-process-cards p { color: var(--muted); line-height: 1.72; font-size: .88rem; }

/* About */
.v11-about-grid { display: grid; grid-template-columns: minmax(0, 1fr) 420px; gap: clamp(32px, 6vw, 78px); align-items: start; }
.v11-value-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.v11-value-grid div { padding: 22px; }
.v11-value-grid span { color: var(--gold); font-family: var(--font-display); font-size: 1.4rem; }
.v11-value-grid h3 { margin: 12px 0 0; color: var(--ink); }
.v11-value-grid p { color: var(--muted); line-height: 1.7; font-size: .9rem; }
.v11-profile-card { padding: 30px; color: var(--ink); background: var(--paper); border-color: var(--line); box-shadow: var(--shadow-soft); }
.v11-profile-card .v11-signal-list div { border-color: var(--line); }
.v11-profile-card .v11-signal-list span { color: var(--soft); }
.v11-profile-card .v11-signal-list strong { color: var(--ink); }

/* Legalitas */
.v11-filter-bar { display: grid; grid-template-columns: minmax(220px, 1fr) 260px auto; gap: 12px; align-items: center; padding: 16px; border: 1px solid var(--line); border-radius: 26px; background: var(--paper); box-shadow: var(--shadow-soft); }
.v11-filter-bar input, .v11-filter-bar select, .form-group input, .form-group select, .form-group textarea {
    width: 100%;
    border: 1px solid rgba(91,22,29,.16);
    border-radius: 16px;
    background: #FFFCF6;
    color: var(--ink);
    min-height: 48px;
    padding: 13px 14px;
    font: inherit;
    outline: none;
}
.v11-filter-bar input:focus, .v11-filter-bar select:focus, .form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: rgba(139,10,26,.44); box-shadow: 0 0 0 4px rgba(139,10,26,.08); }
.v11-filter-bar span { color: var(--muted); font-size: .84rem; font-weight: 700; }
.v11-kbli-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.v11-kbli-card { display: grid; grid-template-columns: 104px 1fr; gap: 18px; padding: 20px; align-items: start; }
.v11-kbli-card.is-hidden { display: none; }
.kbli-copy { border: 0; border-radius: 18px; background: var(--red-dark); color: var(--gold-light); min-height: 74px; font-family: var(--font-display); font-size: 1.6rem; cursor: pointer; }
.v11-kbli-card span { display: block; color: var(--gold); font-size: .72rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.v11-kbli-card h2 { margin: 8px 0 0; color: var(--ink); font-size: 1rem; line-height: 1.55; }

/* Contact */
.v11-contact-grid { display: grid; grid-template-columns: minmax(0, 1fr) 410px; gap: clamp(28px, 5vw, 70px); align-items: start; }
.v11-contact-form { padding: clamp(24px, 3vw, 36px); color: var(--ink); background: var(--paper); border-color: var(--line); box-shadow: var(--shadow-soft); }
.v11-contact-form h2 { color: var(--ink); margin-bottom: 24px; }
.form-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; margin-bottom: 8px; color: var(--ink); font-size: .82rem; font-weight: 800; }
.form-group label span { color: var(--red); }
.form-group textarea { min-height: 134px; resize: vertical; }
.form-hp-field { position: absolute !important; left: -9999px !important; width: 1px !important; height: 1px !important; opacity: 0 !important; }
.form-status { min-height: 42px; margin-top: 12px; padding: 11px 14px; border-radius: 14px; font-size: .86rem; font-weight: 700; display: none; }
.form-status.is-info, .form-status.is-success, .form-status.is-error { display: block; }
.form-status.is-info { background: rgba(201,151,59,.11); color: #7A5517; }
.form-status.is-success { background: rgba(30,128,81,.10); color: #1C6A45; }
.form-status.is-error { background: rgba(139,10,26,.10); color: var(--red-dark); }
.v11-form-note { margin: 12px 0 0; color: var(--muted); font-size: .78rem; line-height: 1.6; text-align: center; }
.v11-contact-side { display: grid; gap: 16px; position: sticky; top: 110px; }
.v11-contact-list { display: grid; gap: 16px; margin-top: 20px; }
.v11-contact-list div { padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.v11-contact-list span { display: block; color: var(--soft); font-size: .72rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.v11-contact-list strong, .v11-contact-list a { display: block; margin-top: 6px; color: var(--ink); font-weight: 800; line-height: 1.6; text-decoration: none; }
.v11-wa-panel { background: linear-gradient(135deg, var(--red-dark), #7E1021); color: var(--paper); border-color: rgba(255,255,255,.12); }
.v11-wa-panel h2 { color: var(--paper); }
.v11-wa-panel p { color: rgba(255,255,255,.70); }
.v11-map-card { padding: 20px; text-align: center; }
.v11-map-card a { color: var(--red-dark); font-weight: 800; text-decoration: none; }

/* Footer */
.v11-footer { padding: clamp(54px, 7vw, 88px) 0 0; background: #180507; color: var(--paper); }
.v11-footer-main { display: grid; grid-template-columns: 360px 1fr; gap: clamp(30px, 6vw, 80px); padding-bottom: 38px; }
.v11-footer-brand { display: grid; gap: 14px; align-content: start; }
.v11-footer .footer-logo-img { width: 76px; height: 76px; object-fit: contain; }
.v11-footer .footer-brand-name { margin: 0; color: var(--paper); font-family: var(--font-display); font-size: 2rem; line-height: 1; }
.v11-footer .footer-brand-tag { margin: 4px 0 0; color: var(--gold-light); font-weight: 800; }
.v11-footer .footer-brand-desc { color: rgba(255,255,255,.62); line-height: 1.75; }
.v11-footer-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 26px; }
.v11-footer .footer-col-title { color: var(--gold-light); font-weight: 800; letter-spacing: .12em; text-transform: uppercase; font-size: .74rem; }
.v11-footer .footer-links { list-style: none; padding: 0; margin: 14px 0 0; display: grid; gap: 10px; }
.v11-footer .footer-links a, .v11-footer .footer-contact-val { color: rgba(255,255,255,.70); text-decoration: none; }
.v11-footer .footer-links a:hover, .v11-footer .footer-contact-val:hover { color: var(--paper); }
.v11-footer .footer-contact { display: grid; gap: 14px; margin-top: 14px; }
.v11-footer .footer-contact-label { display: block; color: rgba(255,255,255,.42); font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; }
.v11-footer .footer-bottom { border-top: 1px solid rgba(255,255,255,.10); padding: 22px 0; display: flex; justify-content: space-between; gap: 18px; color: rgba(255,255,255,.55); }

/* Sticky CTA */
.sticky-mobile-cta { display: none; }

/* Reveal */
.reveal, .reveal-left, .reveal-right, .stagger { opacity: 0; transform: translateY(18px); transition: opacity .55s ease, transform .55s ease; }
.reveal-left { transform: translateX(-20px); }
.reveal-right { transform: translateX(20px); }
.reveal.visible, .reveal-left.visible, .reveal-right.visible, .stagger.visible { opacity: 1; transform: translate(0, 0); }

/* Responsive */
@media (max-width: 1180px) {
    .v11-service-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .v11-process-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .v11-detail-grid, .v11-about-grid, .v11-contact-grid { grid-template-columns: 1fr; }
    .v11-detail-side, .v11-contact-side { position: static; }
}
@media (max-width: 960px) {
    .site-header.v11-header { padding: 12px; }
    .v11-nav { border-radius: 22px; min-height: 64px; }
    .v11-nav .nav-links {
        position: fixed;
        left: 12px;
        right: 12px;
        top: 88px;
        display: none;
        flex-direction: column;
        align-items: stretch;
        padding: 14px;
        border: 1px solid rgba(255,255,255,.12);
        border-radius: 24px;
        background: rgba(25, 5, 8, .97);
        box-shadow: 0 24px 70px rgba(0,0,0,.34);
    }
    .v11-nav .nav-links.open { display: flex; }
    .v11-nav .nav-link { width: 100%; justify-content: flex-start; min-height: 46px; }
    .v11-nav .nav-toggle { display: inline-flex; }
    .v11-hero-grid, .v11-process-grid, .v11-legal-split, .v11-footer-main { grid-template-columns: 1fr; }
    .v11-hero { min-height: auto; }
    .v11-hero-copy h1 { font-size: clamp(3rem, 12vw, 5.5rem); }
    .v11-cta-inner { align-items: flex-start; flex-direction: column; }
    .v11-filter-bar { grid-template-columns: 1fr; }
    .v11-footer-grid { grid-template-columns: 1fr; }
    .v11-footer .footer-bottom { flex-direction: column; }
}
@media (max-width: 700px) {
    .container, .footer-inner { width: min(100% - 24px, var(--container)); }
    .section { padding: 58px 0; }
    .v11-page-hero { padding-top: 128px; }
    .v11-hero { padding-top: 128px; }
    .v11-brand .nav-brand-sub { display: none; }
    .v11-brand-mark { width: 46px; height: 46px; border-radius: 16px; }
    .v11-hero-stats, .v11-strip-grid, .v11-kbli-wall, .v11-post-grid, .v11-check-grid, .v11-benefit-grid, .v11-value-grid, .v11-kbli-grid, .form-row { grid-template-columns: 1fr; }
    .v11-service-grid { grid-template-columns: 1fr; }
    .v11-service-card { min-height: 260px; }
    .v11-process-list article, .v11-time-item, .v11-kbli-card { grid-template-columns: 1fr; }
    .v11-process-cards { grid-template-columns: 1fr; }
    .v11-work-head { flex-direction: column; }
    .v11-page-hero h1 { font-size: clamp(2.7rem, 14vw, 4.5rem); }
    .section-title { font-size: clamp(2.3rem, 12vw, 3.8rem); }
    .sticky-mobile-cta {
        position: fixed;
        left: 12px;
        right: 12px;
        bottom: 12px;
        z-index: 999;
        display: none;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        padding: 8px;
        border-radius: 22px;
        background: rgba(24,5,7,.92);
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        box-shadow: 0 20px 60px rgba(0,0,0,.30);
    }
    .sticky-mobile-cta.is-visible { display: grid; }
    .sticky-mobile-cta a { min-height: 44px; border-radius: 999px; display: grid; place-items: center; text-decoration: none; font-size: .82rem; font-weight: 800; }
    .sticky-cta-primary { color: #261007; background: var(--gold-light); }
    .sticky-cta-secondary { color: var(--paper); background: rgba(255,255,255,.10); }
}
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
    .reveal, .reveal-left, .reveal-right, .stagger { opacity: 1; transform: none; }
}
