/* =========================================================
   Saung Hosting — per-product page redesign
   Used by body.product-page (shared/vps/wp variants)
   ========================================================= */

/* shared base */
.pp-sec { padding: 56px 0; }
.pp-sec.tight { padding: 36px 0; }
.pp-sec .container, .pp-wrap { max-width: 1180px; margin: 0 auto; padding: 0 20px; }
.pp-sec .h-cap { text-align: center; max-width: 760px; margin: 0 auto 28px; }
.pp-sec .h-cap .ey { display: inline-block; padding: 4px 14px; border-radius: 999px; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 10px; }
.pp-sec .h-cap h2 { font-size: 30px; font-weight: 800; letter-spacing: -0.02em; line-height: 1.18; margin: 0 0 8px; color: #0f172a; }
.pp-sec .h-cap p { font-size: 15px; color: #475569; line-height: 1.6; margin: 0; }

/* ======= shared hosting (clean blue) ======= */
body.pp-shared .pp-sec.alt { background: #f8fafc; }
body.pp-shared .pp-sec .h-cap .ey { background: #dbeafe; color: #1d4ed8; }

/* hero stat strip */
.pp-stat-strip { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; margin-top: -40px; position: relative; z-index: 5; padding: 0 20px; max-width: 1180px; margin-left: auto; margin-right: auto; }
@media (min-width: 720px) { .pp-stat-strip { grid-template-columns: repeat(4,1fr); margin-top: -56px; } }
.pp-stat-strip .it { background: #fff; border: 1px solid #e2e8f0; border-radius: 14px; padding: 18px 16px; box-shadow: 0 6px 18px rgba(15,23,42,.06); display: flex; align-items: center; gap: 12px; }
.pp-stat-strip .ic { width: 44px; height: 44px; flex: 0 0 44px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 18px; }
body.pp-shared .pp-stat-strip .ic { background: linear-gradient(135deg,#3b82f6,#2563eb); }
.pp-stat-strip .it b { display: block; font-size: 20px; font-weight: 800; line-height: 1; color: #0f172a; letter-spacing: -.02em; }
.pp-stat-strip .it span { display: block; font-size: 12px; color: #64748b; margin-top: 4px; }

/* benchmark bars */
.pp-bench { display: grid; gap: 14px; max-width: 720px; margin: 0 auto; }
.pp-bench .row { font-size: 13px; }
.pp-bench .lab { display: flex; justify-content: space-between; font-weight: 600; color: #334155; margin-bottom: 6px; }
.pp-bench .bar { height: 12px; background: #f1f5f9; border-radius: 999px; overflow: hidden; }
.pp-bench .bar i { display: block; height: 100%; border-radius: 999px; }
.pp-bench .row.us .bar i { background: linear-gradient(90deg,#22c55e,#16a34a); }
.pp-bench .row.mid .bar i { background: linear-gradient(90deg,#f59e0b,#d97706); }
.pp-bench .row.bad .bar i { background: linear-gradient(90deg,#ef4444,#b91c1c); }
.pp-bench-note { text-align: center; font-size: 12px; color: #64748b; margin-top: 14px; }

/* feature tiles 6 col */
.pp-tiles { display: grid; gap: 14px; grid-template-columns: 1fr; }
@media(min-width:640px){ .pp-tiles { grid-template-columns: repeat(2,1fr); } }
@media(min-width:980px){ .pp-tiles { grid-template-columns: repeat(3,1fr); } }
.pp-tiles .card { background: #fff; border: 1px solid #e2e8f0; border-radius: 16px; padding: 22px 20px; transition: .25s; position: relative; overflow: hidden; }
.pp-tiles .card:hover { transform: translateY(-3px); border-color: #93c5fd; box-shadow: 0 12px 28px rgba(15,23,42,.08); }
.pp-tiles .card .ic { width: 44px; height: 44px; border-radius: 11px; display: inline-flex; align-items: center; justify-content: center; color: #fff; font-size: 18px; margin-bottom: 12px; }
body.pp-shared .pp-tiles .card .ic { background: linear-gradient(135deg,#3b82f6,#1d4ed8); }
.pp-tiles .card h4 { font-size: 16px; font-weight: 700; margin: 0 0 6px; color: #0f172a; }
.pp-tiles .card p { font-size: 13.5px; color: #64748b; margin: 0; line-height: 1.55; }

/* comparison table */
.pp-cmp { background: #fff; border: 1px solid #e2e8f0; border-radius: 18px; overflow: hidden; }
.pp-cmp table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.pp-cmp th, .pp-cmp td { padding: 12px 16px; text-align: left; border-top: 1px solid #f1f5f9; }
.pp-cmp thead th { background: #f8fafc; font-weight: 700; color: #0f172a; font-size: 12px; text-transform: uppercase; letter-spacing: .08em; border-top: none; }
.pp-cmp .us { color: #16a34a; font-weight: 700; }
.pp-cmp .x { color: #dc2626; }
.pp-cmp .col-us { background: #eff6ff; }
body.pp-shared .pp-cmp thead .col-us { background: #dbeafe; color: #1d4ed8; }

/* marquee */
.pp-marq { display: flex; gap: 14px; overflow: hidden; mask-image: linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.pp-marq .lane { display: flex; gap: 14px; animation: ppmar 32s linear infinite; }
.pp-marq .chip { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 10px 16px; font-size: 13px; color: #0f172a; font-weight: 600; white-space: nowrap; display: inline-flex; align-items: center; gap: 8px; box-shadow: 0 1px 2px rgba(0,0,0,.03); }
.pp-marq .chip i { color: #f59e0b; }
@keyframes ppmar { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* faq */
.pp-faq { max-width: 820px; margin: 0 auto; }
.pp-faq details { background: #fff; border: 1px solid #e2e8f0; border-radius: 12px; padding: 14px 18px; margin-bottom: 10px; }
.pp-faq summary { cursor: pointer; font-weight: 700; font-size: 14.5px; color: #0f172a; list-style: none; display: flex; justify-content: space-between; align-items: center; }
.pp-faq summary::-webkit-details-marker { display: none; }
.pp-faq summary::after { content: "+"; color: #2563eb; font-size: 22px; font-weight: 700; line-height: 1; }
body.pp-vps .pp-faq summary::after { color: #06b6d4; }
body.pp-wp .pp-faq summary::after { color: #a855f7; }
.pp-faq details[open] summary::after { content: "−"; }
.pp-faq details p { margin: 10px 0 0; font-size: 13.5px; color: #475569; line-height: 1.65; }

/* ======= VPS HOSTING (LIGHT teal — NO DARK) ======= */
body.pp-vps .pp-sec.alt { background: #f0fdfa; }
body.pp-vps .pp-sec .h-cap .ey { background: #ccfbf1; color: #0f766e; }
body.pp-vps .pp-stat-strip .ic { background: linear-gradient(135deg,#14b8a6,#0891b2); }
body.pp-vps .pp-tiles .card .ic { background: linear-gradient(135deg,#14b8a6,#0891b2); }
body.pp-vps .pp-tiles .card:hover { border-color: #5eead4; box-shadow: 0 12px 28px rgba(20,184,166,.14); }
body.pp-vps .pp-cmp thead .col-us { background: #ccfbf1; color: #0f766e; }
body.pp-vps .pp-cmp .col-us { background: #f0fdfa; }

/* spec gauges (LIGHT) */
.pp-spec-grid { display: grid; gap: 18px; grid-template-columns: 1fr; }
@media(min-width:720px){ .pp-spec-grid { grid-template-columns: repeat(3,1fr); } }
.pp-spec { background: #fff; border: 1px solid #e2e8f0; border-radius: 18px; padding: 28px 22px; text-align: center; transition: .25s; }
.pp-spec:hover { transform: translateY(-3px); border-color: #5eead4; box-shadow: 0 12px 28px rgba(20,184,166,.12); }
.pp-spec .gauge { --p: 70; --c: #14b8a6; width: 140px; height: 140px; border-radius: 50%; background: conic-gradient(var(--c) calc(var(--p) * 1%), #f1f5f9 0); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 16px; position: relative; }
.pp-spec .gauge::before { content: ""; width: 108px; height: 108px; background: #fff; border-radius: 50%; position: absolute; box-shadow: inset 0 1px 3px rgba(0,0,0,.04); }
.pp-spec .gauge .v { position: relative; font-size: 24px; font-weight: 800; color: #0f172a; letter-spacing: -.02em; line-height: 1; }
.pp-spec .gauge .v small { display: block; font-size: 10px; color: #64748b; font-weight: 600; margin-top: 4px; letter-spacing: .1em; }
.pp-spec h4 { font-size: 16px; font-weight: 700; color: #0f172a; margin: 0 0 6px; }
.pp-spec p { font-size: 13px; color: #64748b; margin: 0; line-height: 1.55; }

/* OS templates (LIGHT) */
.pp-os { display: grid; gap: 12px; grid-template-columns: repeat(2,1fr); }
@media(min-width:640px){ .pp-os { grid-template-columns: repeat(3,1fr); } }
@media(min-width:900px){ .pp-os { grid-template-columns: repeat(6,1fr); } }
.pp-os .o { background: #fff; border: 1px solid #e2e8f0; border-radius: 14px; padding: 20px 12px; text-align: center; transition: .2s; }
.pp-os .o:hover { border-color: #5eead4; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(20,184,166,.10); }
.pp-os .o i { font-size: 32px; margin-bottom: 10px; display: block; }
.pp-os .o .nm { font-size: 13px; font-weight: 700; color: #0f172a; }
.pp-os .o .vr { font-size: 11px; color: #64748b; margin-top: 3px; }

/* DC viz (LIGHT) */
.pp-dc { background: linear-gradient(135deg,#f0fdfa 0%,#ecfeff 100%); border: 1px solid #99f6e4; border-radius: 22px; padding: 32px; position: relative; min-height: 300px; overflow: hidden; }
.pp-dc::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 85% 15%, rgba(20,184,166,.10) 0, transparent 38%), radial-gradient(circle at 15% 85%, rgba(8,145,178,.10) 0, transparent 38%); pointer-events: none; }
.pp-dc-grid { display: grid; gap: 24px; grid-template-columns: 1fr; position: relative; align-items: center; }
@media(min-width:760px){ .pp-dc-grid { grid-template-columns: 1fr 1fr; } }
.pp-dc-info h3 { color: #0f172a; font-size: 22px; margin: 0 0 10px; font-weight: 800; letter-spacing: -.02em; }
.pp-dc-info p { color: #475569; font-size: 14px; line-height: 1.65; margin: 0 0 18px; }
.pp-dc-pings { display: grid; gap: 8px; }
.pp-dc-pings .p { display: flex; justify-content: space-between; align-items: center; padding: 10px 14px; background: #fff; border-left: 3px solid #14b8a6; border-radius: 8px; font-size: 13px; box-shadow: 0 1px 2px rgba(15,23,42,.04); }
.pp-dc-pings .p .city { color: #334155; font-weight: 600; display: inline-flex; align-items: center; gap: 6px; }
.pp-dc-pings .p .city i { color: #14b8a6; }
.pp-dc-pings .p .ms { color: #0f766e; font-weight: 700; font-family: 'SF Mono', Menlo, monospace; font-size: 12.5px; padding: 3px 8px; background: #ccfbf1; border-radius: 6px; }
.pp-dc-cir { position: relative; min-height: 260px; }
.pp-dc-cir .core { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg,#14b8a6,#0891b2); display: flex; align-items: center; justify-content: center; color: #fff; box-shadow: 0 0 0 8px rgba(20,184,166,.15), 0 0 0 22px rgba(20,184,166,.06), 0 8px 20px rgba(20,184,166,.25); z-index: 3; }
.pp-dc-cir .core i { font-size: 28px; }
.pp-dc-cir .ring1, .pp-dc-cir .ring2 { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); border-radius: 50%; border: 1.5px dashed rgba(20,184,166,.45); }
.pp-dc-cir .ring1 { width: 150px; height: 150px; animation: pp-rot 22s linear infinite; }
.pp-dc-cir .ring2 { width: 240px; height: 240px; animation: pp-rot 36s linear infinite reverse; }
.pp-dc-cir .ring1 i, .pp-dc-cir .ring2 i { position: absolute; width: 38px; height: 38px; border-radius: 50%; background: #fff; border: 1px solid #99f6e4; display: inline-flex; align-items: center; justify-content: center; color: #0d9488; font-size: 15px; box-shadow: 0 4px 10px rgba(20,184,166,.18); }
.pp-dc-cir .ring1 i:nth-child(1){ top: -19px; left: calc(50% - 19px); }
.pp-dc-cir .ring1 i:nth-child(2){ bottom: -19px; left: calc(50% - 19px); }
.pp-dc-cir .ring2 i:nth-child(1){ top: calc(50% - 19px); left: -19px; }
.pp-dc-cir .ring2 i:nth-child(2){ top: calc(50% - 19px); right: -19px; }
.pp-dc-cir .ring2 i:nth-child(3){ top: 14%; right: 8%; }
.pp-dc-cir .ring2 i:nth-child(4){ bottom: 14%; left: 8%; }
@keyframes pp-rot { from { transform: translate(-50%,-50%) rotate(0deg);} to { transform: translate(-50%,-50%) rotate(360deg);} }

/* ======= WORDPRESS HOSTING (purple/wp) ======= */
body.pp-wp .pp-sec.alt { background: #faf5ff; }
body.pp-wp .pp-sec .h-cap .ey { background: #f3e8ff; color: #7e22ce; }
body.pp-wp .pp-stat-strip .ic { background: linear-gradient(135deg,#a855f7,#7e22ce); }
body.pp-wp .pp-tiles .card .ic { background: linear-gradient(135deg,#a855f7,#7e22ce); }
body.pp-wp .pp-tiles .card:hover { border-color: #d8b4fe; box-shadow: 0 12px 28px rgba(168,85,247,.12); }
body.pp-wp .pp-cmp thead .col-us { background: #f3e8ff; color: #7e22ce; }

/* WP pagespeed gauges (before/after) */
.pp-ps { display: grid; gap: 24px; grid-template-columns: 1fr; align-items: center; }
@media(min-width:760px){ .pp-ps { grid-template-columns: 1fr auto 1fr; } }
.pp-ps-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 18px; padding: 26px 22px; text-align: center; }
.pp-ps-card.bad { background: #fef2f2; border-color: #fecaca; }
.pp-ps-card.good { background: #f0fdf4; border-color: #bbf7d0; }
.pp-ps-card .label { font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 14px; }
.pp-ps-card.bad .label { color: #dc2626; }
.pp-ps-card.good .label { color: #16a34a; }
.pp-ps-gauge { --p: 30; --c: #ef4444; width: 150px; height: 150px; border-radius: 50%; background: conic-gradient(var(--c) calc(var(--p)*1%), #fff 0); display: inline-flex; align-items: center; justify-content: center; position: relative; margin-bottom: 14px; }
.pp-ps-gauge::before { content: ""; width: 116px; height: 116px; background: inherit; border-radius: 50%; position: absolute; }
.pp-ps-card.bad .pp-ps-gauge::before { background: #fef2f2; }
.pp-ps-card.good .pp-ps-gauge::before { background: #f0fdf4; }
.pp-ps-gauge .n { position: relative; font-size: 36px; font-weight: 800; color: #0f172a; letter-spacing: -.02em; }
.pp-ps-card .metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 14px; text-align: left; }
.pp-ps-card .metrics .m { background: rgba(255,255,255,.6); padding: 8px 10px; border-radius: 8px; }
.pp-ps-card .metrics .k { font-size: 10.5px; color: #64748b; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }
.pp-ps-card .metrics .v { font-size: 14px; font-weight: 700; color: #0f172a; margin-top: 2px; }
.pp-ps-arrow { font-size: 36px; color: #a855f7; text-align: center; }
@media(max-width:759px){ .pp-ps-arrow { transform: rotate(90deg); } }

/* WP staging workflow */
.pp-flow { display: grid; gap: 14px; grid-template-columns: 1fr; counter-reset: pp-step; }
@media(min-width:720px){ .pp-flow { grid-template-columns: repeat(4,1fr); } }
.pp-flow .step { background: #fff; border: 1px solid #e2e8f0; border-radius: 16px; padding: 22px 20px; position: relative; counter-increment: pp-step; }
.pp-flow .step::before { content: counter(pp-step); position: absolute; top: -14px; left: 20px; width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg,#a855f7,#7e22ce); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 14px; }
.pp-flow .step h4 { font-size: 15px; font-weight: 700; color: #0f172a; margin: 14px 0 6px; }
.pp-flow .step p { font-size: 13px; color: #64748b; margin: 0; line-height: 1.55; }
.pp-flow .step i { font-size: 22px; color: #a855f7; }

/* WP plugin compatibility chips */
.pp-plug { display: grid; gap: 12px; grid-template-columns: repeat(2,1fr); }
@media(min-width:640px){ .pp-plug { grid-template-columns: repeat(4,1fr); } }
.pp-plug .pl { background: #fff; border: 1px solid #e2e8f0; border-radius: 14px; padding: 14px 12px; text-align: center; transition: .2s; }
.pp-plug .pl:hover { border-color: #d8b4fe; transform: translateY(-2px); }
.pp-plug .pl .lg { width: 44px; height: 44px; border-radius: 11px; background: linear-gradient(135deg,#f3e8ff,#fff); display: inline-flex; align-items: center; justify-content: center; color: #7e22ce; font-size: 22px; margin-bottom: 8px; }
.pp-plug .pl .nm { font-size: 12.5px; font-weight: 700; color: #0f172a; }
.pp-plug .pl .ok { font-size: 10.5px; color: #16a34a; font-weight: 700; margin-top: 2px; display: inline-flex; align-items: center; gap: 3px; }

/* utility: tighten the existing PageHero on these pages */
body.pp-shared .idc-page-hero, body.pp-vps .idc-page-hero, body.pp-wp .idc-page-hero { padding-bottom: 80px; }
body.pp-vps .idc-page-hero { background: linear-gradient(135deg,#f0fdfa 0%,#ecfeff 50%,#fff 100%); }
body.pp-vps .idc-page-hero .grad { background: linear-gradient(90deg,#0d9488,#0891b2); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
body.pp-wp .idc-page-hero { background: linear-gradient(135deg,#faf5ff 0%,#f3e8ff 50%,#fff 100%); }
body.pp-wp .idc-page-hero .grad { background: linear-gradient(90deg,#a855f7,#7e22ce); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

/* ======= CLOUD HOSTING (sky blue) ======= */
body.pp-cloud .pp-sec.alt { background: #f0f9ff; }
body.pp-cloud .pp-sec .h-cap .ey { background: #e0f2fe; color: #0369a1; }
body.pp-cloud .pp-stat-strip .ic { background: linear-gradient(135deg,#0ea5e9,#0369a1); }
body.pp-cloud .pp-tiles .card .ic { background: linear-gradient(135deg,#0ea5e9,#0369a1); }
body.pp-cloud .pp-tiles .card:hover { border-color: #7dd3fc; box-shadow: 0 12px 28px rgba(14,165,233,.14); }
body.pp-cloud .pp-cmp thead .col-us { background: #e0f2fe; color: #0369a1; }
body.pp-cloud .pp-cmp .col-us { background: #f0f9ff; }
body.pp-cloud .idc-page-hero { background: linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 50%,#fff 100%); }
body.pp-cloud .idc-page-hero .grad { background: linear-gradient(90deg,#0369a1,#0ea5e9); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
body.pp-cloud .idc-page-hero { padding-bottom: 80px; }
body.pp-cloud .pp-faq summary::after { color: #0ea5e9; }

/* cloud architecture viz */
.pp-arch { background: linear-gradient(135deg,#f0f9ff 0%,#ecfeff 100%); border: 1px solid #bae6fd; border-radius: 22px; padding: 36px 28px; position: relative; overflow: hidden; }
.pp-arch::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 50% 0%, rgba(14,165,233,.08) 0, transparent 50%); pointer-events: none; }
.pp-arch-layers { display: grid; gap: 18px; position: relative; }
.pp-arch-row { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; align-items: stretch; }
.pp-arch-node { background: #fff; border: 1px solid #bae6fd; border-radius: 14px; padding: 16px 20px; min-width: 130px; text-align: center; box-shadow: 0 4px 14px rgba(14,165,233,.08); flex: 1 1 130px; max-width: 200px; }
.pp-arch-node i { font-size: 24px; color: #0ea5e9; display: block; margin-bottom: 6px; }
.pp-arch-node .nm { font-size: 13px; font-weight: 700; color: #0f172a; }
.pp-arch-node .sub { font-size: 11px; color: #64748b; margin-top: 2px; }
.pp-arch-node.pri { background: linear-gradient(135deg,#0ea5e9,#0369a1); color: #fff; border-color: #0ea5e9; }
.pp-arch-node.pri i, .pp-arch-node.pri .nm { color: #fff; }
.pp-arch-node.pri .sub { color: rgba(255,255,255,.85); }
.pp-arch-arrow { text-align: center; color: #7dd3fc; font-size: 22px; }

/* uptime ring */
.pp-up { display: grid; gap: 18px; grid-template-columns: 1fr; }
@media(min-width:720px){ .pp-up { grid-template-columns: repeat(3,1fr); } }
.pp-up .u { background: #fff; border: 1px solid #e2e8f0; border-radius: 18px; padding: 26px 22px; text-align: center; }
.pp-up .u .ring { --p: 99; width: 130px; height: 130px; border-radius: 50%; background: conic-gradient(#0ea5e9 calc(var(--p)*1%), #f1f5f9 0); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 14px; position: relative; }
.pp-up .u .ring::before { content: ""; width: 100px; height: 100px; background: #fff; border-radius: 50%; position: absolute; }
.pp-up .u .ring .v { position: relative; font-size: 22px; font-weight: 800; color: #0369a1; letter-spacing: -.02em; }
.pp-up .u h4 { font-size: 16px; font-weight: 700; color: #0f172a; margin: 0 0 4px; }
.pp-up .u p { font-size: 13px; color: #64748b; margin: 0; }

/* ======= EMAIL HOSTING (amber/orange) ======= */
body.pp-email .pp-sec.alt { background: #fffbeb; }
body.pp-email .pp-sec .h-cap .ey { background: #fef3c7; color: #b45309; }
body.pp-email .pp-stat-strip .ic { background: linear-gradient(135deg,#f59e0b,#d97706); }
body.pp-email .pp-tiles .card .ic { background: linear-gradient(135deg,#f59e0b,#d97706); }
body.pp-email .pp-tiles .card:hover { border-color: #fcd34d; box-shadow: 0 12px 28px rgba(245,158,11,.14); }
body.pp-email .pp-cmp thead .col-us { background: #fef3c7; color: #b45309; }
body.pp-email .pp-cmp .col-us { background: #fffbeb; }
body.pp-email .idc-page-hero { background: linear-gradient(135deg,#fffbeb 0%,#fef3c7 50%,#fff 100%); }
body.pp-email .idc-page-hero .grad { background: linear-gradient(90deg,#d97706,#f59e0b); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
body.pp-email .idc-page-hero { padding-bottom: 80px; }
body.pp-email .pp-faq summary::after { color: #f59e0b; }

/* email mockup */
.pp-mail { background: #fff; border: 1px solid #fde68a; border-radius: 18px; overflow: hidden; box-shadow: 0 14px 30px rgba(245,158,11,.08); max-width: 720px; margin: 0 auto; }
.pp-mail-bar { background: linear-gradient(90deg,#fffbeb,#fef3c7); padding: 14px 18px; border-bottom: 1px solid #fde68a; display: flex; align-items: center; gap: 10px; }
.pp-mail-bar .dot { width: 10px; height: 10px; border-radius: 50%; background: #fcd34d; }
.pp-mail-bar .from { font-size: 13px; color: #78350f; font-weight: 700; }
.pp-mail-body { padding: 18px 22px; }
.pp-mail-body .row { padding: 8px 0; border-bottom: 1px solid #fef3c7; display: flex; gap: 12px; align-items: center; font-size: 13px; }
.pp-mail-body .row:last-child { border-bottom: none; }
.pp-mail-body .av { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg,#f59e0b,#d97706); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; flex: 0 0 36px; }
.pp-mail-body .meta { flex: 1; min-width: 0; }
.pp-mail-body .meta b { color: #0f172a; display: block; font-size: 13.5px; }
.pp-mail-body .meta span { color: #64748b; font-size: 12px; display: block; }
.pp-mail-body .tm { color: #b45309; font-size: 11px; font-weight: 700; }

/* protocol grid */
.pp-proto { display: grid; gap: 14px; grid-template-columns: repeat(2,1fr); }
@media(min-width:720px){ .pp-proto { grid-template-columns: repeat(4,1fr); } }
.pp-proto .pr { background: #fff; border: 1px solid #fde68a; border-radius: 14px; padding: 18px 14px; text-align: center; }
.pp-proto .pr i { font-size: 26px; color: #d97706; display: block; margin-bottom: 8px; }
.pp-proto .pr b { font-size: 14px; color: #0f172a; display: block; }
.pp-proto .pr span { font-size: 11.5px; color: #64748b; display: block; margin-top: 3px; }

/* ======= RESELLER (green) ======= */
body.pp-reseller .pp-sec.alt { background: #f0fdf4; }
body.pp-reseller .pp-sec .h-cap .ey { background: #dcfce7; color: #15803d; }
body.pp-reseller .pp-stat-strip .ic { background: linear-gradient(135deg,#22c55e,#15803d); }
body.pp-reseller .pp-tiles .card .ic { background: linear-gradient(135deg,#22c55e,#15803d); }
body.pp-reseller .pp-tiles .card:hover { border-color: #86efac; box-shadow: 0 12px 28px rgba(34,197,94,.14); }
body.pp-reseller .pp-cmp thead .col-us { background: #dcfce7; color: #15803d; }
body.pp-reseller .pp-cmp .col-us { background: #f0fdf4; }
body.pp-reseller .idc-page-hero { background: linear-gradient(135deg,#f0fdf4 0%,#dcfce7 50%,#fff 100%); }
body.pp-reseller .idc-page-hero .grad { background: linear-gradient(90deg,#15803d,#22c55e); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
body.pp-reseller .idc-page-hero { padding-bottom: 80px; }
body.pp-reseller .pp-faq summary::after { color: #22c55e; }

/* profit calculator */
.pp-calc { background: #fff; border: 1px solid #bbf7d0; border-radius: 18px; padding: 28px; max-width: 760px; margin: 0 auto; }
.pp-calc-grid { display: grid; gap: 18px; grid-template-columns: 1fr; }
@media(min-width:640px){ .pp-calc-grid { grid-template-columns: 1fr 1fr 1fr; } }
.pp-calc-col { background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 14px; padding: 18px; text-align: center; }
.pp-calc-col .lbl { font-size: 11.5px; color: #15803d; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.pp-calc-col .val { font-size: 28px; font-weight: 800; color: #0f172a; margin-top: 6px; letter-spacing: -.02em; }
.pp-calc-col .sub { font-size: 12px; color: #64748b; margin-top: 4px; }
.pp-calc-col.hi { background: linear-gradient(135deg,#22c55e,#15803d); border-color: #15803d; }
.pp-calc-col.hi .lbl, .pp-calc-col.hi .val, .pp-calc-col.hi .sub { color: #fff; }
.pp-calc-col.hi .sub { color: rgba(255,255,255,.85); }

/* WHM features */
.pp-whm { display: grid; gap: 14px; grid-template-columns: 1fr; }
@media(min-width:720px){ .pp-whm { grid-template-columns: repeat(2,1fr); } }
.pp-whm .w { background: #fff; border: 1px solid #e2e8f0; border-radius: 16px; padding: 20px; display: flex; gap: 14px; align-items: flex-start; }
.pp-whm .w .ic { width: 44px; height: 44px; border-radius: 11px; background: linear-gradient(135deg,#22c55e,#15803d); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 18px; flex: 0 0 44px; }
.pp-whm .w .tx h4 { font-size: 15px; font-weight: 700; color: #0f172a; margin: 0 0 4px; }
.pp-whm .w .tx p { font-size: 13px; color: #64748b; margin: 0; line-height: 1.55; }

/* ======= PROMO (red/pink — limited time) ======= */
body.pp-promo .pp-sec.alt { background: #fff1f2; }
body.pp-promo .pp-sec .h-cap .ey { background: #ffe4e6; color: #be123c; }
body.pp-promo .pp-stat-strip .ic { background: linear-gradient(135deg,#f43f5e,#be123c); }
body.pp-promo .pp-tiles .card .ic { background: linear-gradient(135deg,#f43f5e,#be123c); }
body.pp-promo .pp-tiles .card:hover { border-color: #fda4af; box-shadow: 0 12px 28px rgba(244,63,94,.14); }
body.pp-promo .pp-cmp thead .col-us { background: #ffe4e6; color: #be123c; }
body.pp-promo .pp-cmp .col-us { background: #fff1f2; }
body.pp-promo .idc-page-hero { background: linear-gradient(135deg,#fff1f2 0%,#ffe4e6 50%,#fff 100%); }
body.pp-promo .idc-page-hero .grad { background: linear-gradient(90deg,#be123c,#f43f5e); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
body.pp-promo .idc-page-hero { padding-bottom: 80px; }
body.pp-promo .pp-faq summary::after { color: #f43f5e; }

/* countdown */
.pp-cd { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; max-width: 560px; margin: 0 auto 8px; }
.pp-cd .b { background: linear-gradient(135deg,#f43f5e,#be123c); color: #fff; border-radius: 14px; padding: 14px 8px; min-width: 80px; text-align: center; box-shadow: 0 8px 20px rgba(244,63,94,.20); }
.pp-cd .b .n { font-size: 32px; font-weight: 800; line-height: 1; letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.pp-cd .b .l { font-size: 10px; text-transform: uppercase; letter-spacing: .12em; margin-top: 6px; opacity: .9; }
.pp-cd-cap { text-align: center; font-size: 13px; color: #be123c; font-weight: 700; margin-top: 12px; }

/* deal grid */
.pp-deals { display: grid; gap: 16px; grid-template-columns: 1fr; }
@media(min-width:720px){ .pp-deals { grid-template-columns: repeat(3,1fr); } }
.pp-deals .d { background: #fff; border: 2px solid #fda4af; border-radius: 18px; padding: 24px 20px; text-align: center; position: relative; transition: .25s; }
.pp-deals .d:hover { transform: translateY(-3px); box-shadow: 0 14px 30px rgba(244,63,94,.16); }
.pp-deals .d.featured { border-color: #f43f5e; box-shadow: 0 10px 24px rgba(244,63,94,.16); }
.pp-deals .d .ribbon { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: linear-gradient(90deg,#f43f5e,#be123c); color: #fff; font-size: 11px; font-weight: 800; padding: 4px 14px; border-radius: 999px; letter-spacing: .08em; text-transform: uppercase; }
.pp-deals .d .pct { font-size: 44px; font-weight: 800; color: #f43f5e; line-height: 1; letter-spacing: -.03em; margin: 8px 0 4px; }
.pp-deals .d .pct small { font-size: 22px; }
.pp-deals .d .nm { font-size: 16px; font-weight: 700; color: #0f172a; margin-top: 6px; }
.pp-deals .d .ds { font-size: 12.5px; color: #64748b; margin-top: 4px; line-height: 1.5; min-height: 36px; }
.pp-deals .d .pr { margin-top: 12px; }
.pp-deals .d .pr .old { color: #94a3b8; text-decoration: line-through; font-size: 13px; }
.pp-deals .d .pr .new { color: #be123c; font-weight: 800; font-size: 22px; margin-left: 4px; letter-spacing: -.02em; }
.pp-deals .d a { display: inline-block; margin-top: 14px; background: linear-gradient(90deg,#f43f5e,#be123c); color: #fff; padding: 10px 22px; border-radius: 10px; font-weight: 700; text-decoration: none; font-size: 13px; transition: .2s; }
.pp-deals .d a:hover { transform: translateY(-1px); box-shadow: 0 6px 14px rgba(244,63,94,.25); }

/* ===================== pp-web (Jasa Website — violet) ===================== */
body.pp-web .pp-stat-strip .it .ic { background:#ede9fe; color:#7c3aed; }
body.pp-web .pp-sec .h-cap .ey { color:#7c3aed; background:#ede9fe; }
body.pp-web .idc-price.featured { border-color:#7c3aed; box-shadow:0 18px 38px rgba(124,58,237,.18); }
body.pp-web .idc-price .cta { background:linear-gradient(135deg,#8b5cf6,#6d28d9); color:#fff; }
body.pp-web .idc-price .badge-popular { background:#7c3aed; }
body.pp-web .pp-tiles .card .ic { background:#ede9fe; color:#6d28d9; }
body.pp-web .idc-cta-banner { background:linear-gradient(135deg,#5b21b6,#7c3aed); }
body.pp-web .grad { background:linear-gradient(135deg,#7c3aed,#ec4899); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-web-mock { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:24px; }
.pp-web-mock .m { background:#fff; border:1px solid #e5e7eb; border-radius:14px; overflow:hidden; box-shadow:0 8px 22px rgba(0,0,0,.06); }
.pp-web-mock .m .bar { background:#f3f4f6; padding:8px 12px; display:flex; gap:6px; align-items:center; }
.pp-web-mock .m .bar i { width:9px; height:9px; border-radius:50%; background:#ef4444; }
.pp-web-mock .m .bar i:nth-child(2){background:#f59e0b}.pp-web-mock .m .bar i:nth-child(3){background:#10b981}
.pp-web-mock .m .body { padding:14px; }
.pp-web-mock .m .body h5 { font-size:14px; margin:0 0 8px; color:#0f172a; font-weight:700; }
.pp-web-mock .m .body .li { height:8px; background:#e5e7eb; border-radius:4px; margin:6px 0; }
.pp-web-mock .m .body .li.s { width:60%; }
.pp-web-mock .m .body .img { height:70px; background:linear-gradient(135deg,#a78bfa,#ec4899); border-radius:8px; margin:8px 0; }

/* ===================== pp-app (Jasa Aplikasi — indigo) ===================== */
body.pp-app .pp-stat-strip .it .ic { background:#e0e7ff; color:#4338ca; }
body.pp-app .pp-sec .h-cap .ey { color:#4338ca; background:#e0e7ff; }
body.pp-app .idc-price.featured { border-color:#4338ca; box-shadow:0 18px 38px rgba(67,56,202,.18); }
body.pp-app .idc-price .cta { background:linear-gradient(135deg,#6366f1,#4338ca); color:#fff; }
body.pp-app .idc-price .badge-popular { background:#4338ca; }
body.pp-app .pp-tiles .card .ic { background:#e0e7ff; color:#4338ca; }
body.pp-app .idc-cta-banner { background:linear-gradient(135deg,#312e81,#4338ca); }
body.pp-app .grad { background:linear-gradient(135deg,#4338ca,#0ea5e9); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-stack { display:grid; grid-template-columns:repeat(auto-fit,minmax(110px,1fr)); gap:14px; margin-top:24px; }
.pp-stack .s { background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:18px 10px; text-align:center; transition:.2s; }
.pp-stack .s:hover { transform:translateY(-3px); box-shadow:0 10px 24px rgba(67,56,202,.15); }
.pp-stack .s i { font-size:32px; margin-bottom:8px; display:block; }
.pp-stack .s .nm { font-weight:700; font-size:13px; color:#0f172a; }
.pp-flow { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:24px; position:relative; }
.pp-flow .step { background:#fff; border:2px solid #e0e7ff; border-radius:16px; padding:22px 18px; text-align:center; position:relative; }
.pp-flow .step .n { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,#6366f1,#4338ca); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; margin:0 auto 12px; font-size:18px; }
.pp-flow .step h5 { margin:0 0 6px; color:#0f172a; font-weight:700; font-size:15px; }
.pp-flow .step p { margin:0; color:#64748b; font-size:13px; line-height:1.5; }
@media (max-width:768px){ .pp-flow { grid-template-columns:repeat(2,1fr); } }

/* ===================== pp-seo (Jasa SEO — orange) ===================== */
body.pp-seo .pp-stat-strip .it .ic { background:#ffedd5; color:#ea580c; }
body.pp-seo .pp-sec .h-cap .ey { color:#ea580c; background:#ffedd5; }
body.pp-seo .idc-price.featured { border-color:#ea580c; box-shadow:0 18px 38px rgba(234,88,12,.18); }
body.pp-seo .idc-price .cta { background:linear-gradient(135deg,#fb923c,#ea580c); color:#fff; }
body.pp-seo .idc-price .badge-popular { background:#ea580c; }
body.pp-seo .pp-tiles .card .ic { background:#ffedd5; color:#c2410c; }
body.pp-seo .idc-cta-banner { background:linear-gradient(135deg,#9a3412,#ea580c); }
body.pp-seo .grad { background:linear-gradient(135deg,#ea580c,#dc2626); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-serp { background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:22px; box-shadow:0 8px 24px rgba(0,0,0,.05); margin-top:24px; max-width:680px; margin-left:auto; margin-right:auto; }
.pp-serp .q { background:#f9fafb; border:1px solid #e5e7eb; border-radius:30px; padding:10px 18px; display:flex; align-items:center; gap:10px; color:#475569; font-size:14px; margin-bottom:18px; }
.pp-serp .res { padding:14px 0; border-bottom:1px solid #f1f5f9; }
.pp-serp .res:last-child { border-bottom:0; }
.pp-serp .res .url { color:#10b981; font-size:12px; }
.pp-serp .res .ti { color:#1d4ed8; font-size:18px; font-weight:600; margin:4px 0; }
.pp-serp .res .ds { color:#475569; font-size:13px; line-height:1.5; }
.pp-serp .res.us { background:linear-gradient(90deg,#fff7ed,transparent); border-radius:8px; padding-left:10px; }
.pp-serp .res.us .ti { color:#ea580c; }
.pp-serp .rank { display:inline-block; background:#ea580c; color:#fff; font-size:11px; font-weight:700; padding:2px 8px; border-radius:10px; margin-right:8px; }
.pp-rank-bar { display:grid; grid-template-columns:repeat(6,1fr); gap:10px; margin-top:24px; align-items:end; height:160px; }
.pp-rank-bar .b { background:linear-gradient(180deg,#fb923c,#ea580c); border-radius:8px 8px 0 0; position:relative; transition:.4s; }
.pp-rank-bar .b::after { content:attr(data-m); position:absolute; top:-22px; left:50%; transform:translateX(-50%); font-size:11px; color:#475569; font-weight:600; }
.pp-rank-bar .b::before { content:attr(data-r); position:absolute; bottom:-22px; left:50%; transform:translateX(-50%); font-size:11px; color:#94a3b8; }

/* ===================== pp-help (Pusat Bantuan — slate) ===================== */
body.pp-help .pp-stat-strip .it .ic { background:#e2e8f0; color:#334155; }
body.pp-help .pp-sec .h-cap .ey { color:#0f172a; background:#e2e8f0; }
body.pp-help .pp-tiles .card .ic { background:#e2e8f0; color:#0f172a; }
body.pp-help .grad { background:linear-gradient(135deg,#0f172a,#0891b2); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-help-search { max-width:680px; margin:0 auto 24px; }
.pp-help-search .box { background:#fff; border:2px solid #e2e8f0; border-radius:50px; padding:6px 6px 6px 22px; display:flex; align-items:center; gap:10px; box-shadow:0 8px 22px rgba(0,0,0,.05); }
.pp-help-search .box i { color:#94a3b8; font-size:18px; }
.pp-help-search .box input { flex:1; border:0; background:transparent; padding:14px 0; outline:none; font-size:15px; color:#0f172a; }
.pp-help-search .box button { background:linear-gradient(135deg,#0f172a,#1e293b); color:#fff; border:0; padding:12px 26px; border-radius:40px; font-weight:700; cursor:pointer; }
.pp-help-search .tags { margin-top:14px; display:flex; flex-wrap:wrap; gap:8px; justify-content:center; }
.pp-help-search .tags a { background:#fff; border:1px solid #e2e8f0; padding:6px 14px; border-radius:20px; font-size:12px; color:#475569; text-decoration:none; transition:.2s; }
.pp-help-search .tags a:hover { background:#0f172a; color:#fff; border-color:#0f172a; }
.pp-help-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:18px; margin-top:24px; }
.pp-help-cards .c { background:#fff; border:1px solid #e2e8f0; border-radius:16px; padding:24px; transition:.2s; cursor:pointer; }
.pp-help-cards .c:hover { transform:translateY(-3px); box-shadow:0 14px 28px rgba(0,0,0,.08); border-color:#0891b2; }
.pp-help-cards .c .ic { width:48px; height:48px; border-radius:12px; background:linear-gradient(135deg,#0891b2,#0e7490); color:#fff; display:flex; align-items:center; justify-content:center; font-size:20px; margin-bottom:14px; }
.pp-help-cards .c h4 { margin:0 0 6px; font-size:16px; color:#0f172a; font-weight:700; }
.pp-help-cards .c p { margin:0 0 10px; color:#64748b; font-size:13px; line-height:1.55; }
.pp-help-cards .c .lk { color:#0891b2; font-size:13px; font-weight:600; text-decoration:none; }
.pp-contact-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; margin-top:24px; }
.pp-contact-grid .c { background:#fff; border:1px solid #e2e8f0; border-radius:16px; padding:24px; text-align:center; transition:.2s; }
.pp-contact-grid .c:hover { transform:translateY(-3px); box-shadow:0 14px 28px rgba(0,0,0,.08); }
.pp-contact-grid .c .ic { width:60px; height:60px; border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 14px; font-size:26px; color:#fff; }
.pp-contact-grid .c.wa .ic { background:linear-gradient(135deg,#25d366,#128c7e); }
.pp-contact-grid .c.tk .ic { background:linear-gradient(135deg,#0891b2,#0e7490); }
.pp-contact-grid .c.lc .ic { background:linear-gradient(135deg,#f59e0b,#d97706); }
.pp-contact-grid .c.km .ic { background:linear-gradient(135deg,#7c3aed,#5b21b6); }
.pp-contact-grid .c h4 { margin:0 0 4px; color:#0f172a; font-weight:700; font-size:15px; }
.pp-contact-grid .c p { color:#64748b; font-size:13px; margin:0 0 12px; }
.pp-contact-grid .c a { display:inline-block; background:#0f172a; color:#fff; padding:8px 18px; border-radius:30px; font-weight:600; font-size:13px; text-decoration:none; transition:.2s; }
.pp-contact-grid .c a:hover { transform:translateY(-1px); box-shadow:0 6px 14px rgba(15,23,42,.25); }

/* ===================== pp-hub (Web Hosting hub — teal) ===================== */
body.pp-hub .pp-stat-strip .it .ic { background:#ccfbf1; color:#0d9488; }
body.pp-hub .pp-sec .h-cap .ey { color:#0d9488; background:#ccfbf1; }
body.pp-hub .pp-tiles .card .ic { background:#ccfbf1; color:#0d9488; }
body.pp-hub .grad { background:linear-gradient(135deg,#0d9488,#14b8a6); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-hub-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:18px; margin-top:24px; }
.pp-hub-grid .h { background:#fff; border:1px solid #e5e7eb; border-radius:16px; padding:24px; transition:.2s; text-decoration:none; color:#0f172a; display:block; }
.pp-hub-grid .h:hover { transform:translateY(-3px); box-shadow:0 14px 30px rgba(13,148,136,.18); border-color:#14b8a6; }
.pp-hub-grid .h .ic { width:50px; height:50px; border-radius:14px; background:linear-gradient(135deg,#14b8a6,#0d9488); color:#fff; display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:14px; }
.pp-hub-grid .h h4 { font-weight:700; font-size:17px; margin:0 0 6px; }
.pp-hub-grid .h p { color:#64748b; font-size:13px; margin:0 0 10px; line-height:1.55; }
.pp-hub-grid .h .pr { color:#0d9488; font-weight:700; font-size:14px; }

/* ===================== pp-domain (Domain — blue) ===================== */
body.pp-domain .pp-stat-strip .it .ic { background:#dbeafe; color:#1d4ed8; }
body.pp-domain .pp-sec .h-cap .ey { color:#1d4ed8; background:#dbeafe; }
body.pp-domain .idc-price.featured { border-color:#1d4ed8; }
body.pp-domain .idc-price .cta { background:linear-gradient(135deg,#3b82f6,#1d4ed8); color:#fff; }
body.pp-domain .idc-price .badge-popular { background:#1d4ed8; }
body.pp-domain .pp-tiles .card .ic { background:#dbeafe; color:#1d4ed8; }
body.pp-domain .idc-cta-banner { background:linear-gradient(135deg,#1e3a8a,#1d4ed8); }
body.pp-domain .grad { background:linear-gradient(135deg,#1d4ed8,#0ea5e9); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-dsearch { background:#fff; max-width:780px; margin:0 auto 24px; border:2px solid #dbeafe; border-radius:60px; padding:8px 8px 8px 26px; display:flex; align-items:center; gap:10px; box-shadow:0 14px 34px rgba(29,78,216,.14); transition:border-color .2s, box-shadow .2s; }
.pp-dsearch:focus-within { border-color:#3b82f6; box-shadow:0 18px 42px rgba(29,78,216,.22); }
.pp-dsearch i { color:#94a3b8; font-size:22px; }
.pp-dsearch input { flex:1 1 auto; min-width:0; border:0; outline:0; background:transparent; padding:20px 6px; font-size:22px; font-weight:600; color:#0f172a; letter-spacing:.2px; }
.pp-dsearch input::placeholder { color:#94a3b8; font-weight:500; }
.pp-dsearch input.is-err { color:#dc2626; animation:ppShake .35s; }
@keyframes ppShake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-4px)} 75%{transform:translateX(4px)} }
.pp-dsearch select { flex:0 0 auto; border:0; background:#f1f5f9; border-radius:24px; padding:6px 10px; font-size:13px; font-weight:600; color:#1d4ed8; outline:0; cursor:pointer; max-width:110px; }
.pp-dsearch button { flex:0 0 auto; background:linear-gradient(135deg,#3b82f6,#1d4ed8); color:#fff; border:0; padding:14px 30px; border-radius:50px; font-weight:700; font-size:15px; cursor:pointer; box-shadow:0 8px 20px rgba(29,78,216,.28); transition:transform .15s, box-shadow .15s; }
.pp-dsearch button:hover { transform:translateY(-1px); box-shadow:0 12px 26px rgba(29,78,216,.36); }
@media (max-width:560px){
  .pp-dsearch { flex-wrap:wrap; border-radius:24px; padding:12px; gap:8px; }
  .pp-dsearch i { display:none; }
  .pp-dsearch input { flex:1 1 100%; padding:14px 12px; font-size:18px; background:#f8fafc; border-radius:14px; }
  .pp-dsearch select { flex:1 1 auto; max-width:none; padding:10px 12px; font-size:14px; }
  .pp-dsearch button { flex:1 1 auto; padding:12px 18px; }
}
.pp-tld-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:14px; margin-top:24px; }
.pp-tld-grid .t { background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:18px 14px; text-align:center; transition:.2s; }
.pp-tld-grid .t:hover { transform:translateY(-3px); box-shadow:0 12px 26px rgba(29,78,216,.15); border-color:#3b82f6; }
.pp-tld-grid .t .nm { font-weight:800; font-size:22px; color:#1d4ed8; }
.pp-tld-grid .t .pr { color:#0f172a; font-weight:700; font-size:15px; margin-top:6px; }
.pp-tld-grid .t .pr small { color:#94a3b8; font-weight:500; font-size:12px; }
.pp-tfer { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:24px; }
.pp-tfer .s { background:#fff; border:1px solid #e5e7eb; border-radius:14px; padding:18px 14px; text-align:center; }
.pp-tfer .s .n { width:36px; height:36px; border-radius:50%; background:#dbeafe; color:#1d4ed8; display:flex; align-items:center; justify-content:center; font-weight:800; margin:0 auto 8px; }
.pp-tfer .s b { color:#0f172a; font-size:14px; }
.pp-tfer .s p { color:#64748b; font-size:12px; margin:4px 0 0; }
@media (max-width:768px){ .pp-tfer { grid-template-columns:repeat(2,1fr); } }

/* ===================== pp-about (Tentang — slate-cyan) ===================== */
body.pp-about .pp-stat-strip .it .ic { background:#cffafe; color:#0e7490; }
body.pp-about .pp-sec .h-cap .ey { color:#0e7490; background:#cffafe; }
body.pp-about .pp-tiles .card .ic { background:#cffafe; color:#0e7490; }
body.pp-about .grad { background:linear-gradient(135deg,#0e7490,#0891b2); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-stats-big { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:16px; margin-top:24px; }
.pp-stats-big .s { background:linear-gradient(135deg,#0e7490,#0891b2); color:#fff; border-radius:18px; padding:28px; text-align:center; }
.pp-stats-big .s .n { font-size:38px; font-weight:800; line-height:1; margin-bottom:6px; }
.pp-stats-big .s .l { font-size:13px; opacity:.9; }
.pp-tline { position:relative; padding-left:40px; margin-top:24px; }
.pp-tline::before { content:''; position:absolute; left:14px; top:6px; bottom:6px; width:2px; background:linear-gradient(180deg,#0e7490,#0891b2,#06b6d4); }
.pp-tline .it { position:relative; padding:0 0 24px; }
.pp-tline .it::before { content:''; position:absolute; left:-32px; top:6px; width:14px; height:14px; border-radius:50%; background:#0e7490; box-shadow:0 0 0 4px #fff, 0 0 0 6px #cffafe; }
.pp-tline .yr { color:#0e7490; font-weight:800; font-size:14px; }
.pp-tline h4 { color:#0f172a; margin:4px 0 4px; font-size:17px; font-weight:700; }
.pp-tline p { color:#64748b; font-size:14px; margin:0; line-height:1.55; }

/* ===================== pp-blog (Blog — neutral with blue accents) ===================== */
body.pp-blog .pp-stat-strip .it .ic { background:#dbeafe; color:#1d4ed8; }
body.pp-blog .pp-sec .h-cap .ey { color:#1d4ed8; background:#dbeafe; }
body.pp-blog .grad { background:linear-gradient(135deg,#1d4ed8,#7c3aed); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-blog-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:20px; margin-top:24px; }
.pp-blog-grid .p { background:#fff; border:1px solid #e5e7eb; border-radius:16px; overflow:hidden; transition:.2s; text-decoration:none; color:#0f172a; display:flex; flex-direction:column; }
.pp-blog-grid .p:hover { transform:translateY(-3px); box-shadow:0 16px 32px rgba(0,0,0,.08); }
.pp-blog-grid .p .img { height:160px; background:linear-gradient(135deg,#1d4ed8,#7c3aed); position:relative; }
.pp-blog-grid .p .img::after { content:attr(data-cat); position:absolute; left:14px; top:14px; background:rgba(255,255,255,.95); color:#1d4ed8; padding:4px 12px; border-radius:20px; font-size:11px; font-weight:700; }
.pp-blog-grid .p .body { padding:18px; flex:1; display:flex; flex-direction:column; }
.pp-blog-grid .p h4 { font-size:16px; font-weight:700; margin:0 0 8px; line-height:1.4; }
.pp-blog-grid .p .ds { color:#64748b; font-size:13px; line-height:1.55; flex:1; margin:0 0 12px; }
.pp-blog-grid .p .meta { display:flex; align-items:center; gap:10px; color:#94a3b8; font-size:12px; }

/* ===================== pp-contact (Kontak — green/blue) ===================== */
body.pp-contact .pp-stat-strip .it .ic { background:#dcfce7; color:#15803d; }
body.pp-contact .pp-sec .h-cap .ey { color:#15803d; background:#dcfce7; }
body.pp-contact .grad { background:linear-gradient(135deg,#15803d,#0891b2); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-ct-grid { display:grid; grid-template-columns:1.1fr 1fr; gap:28px; margin-top:24px; align-items:start; }
@media (max-width:900px){ .pp-ct-grid { grid-template-columns:1fr; } }
.pp-ct-card { background:#fff; border:1px solid #e5e7eb; border-radius:18px; padding:26px; box-shadow:0 8px 24px rgba(0,0,0,.05); }
.pp-ct-card h3 { font-size:20px; font-weight:800; color:#0f172a; margin:0 0 14px; }
.pp-ct-info .row { display:flex; gap:14px; padding:14px 0; border-bottom:1px solid #f1f5f9; }
.pp-ct-info .row:last-child { border-bottom:0; }
.pp-ct-info .row .ic { width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:18px; flex-shrink:0; }
.pp-ct-info .row.wa .ic { background:linear-gradient(135deg,#25d366,#128c7e); }
.pp-ct-info .row.em .ic { background:linear-gradient(135deg,#0891b2,#0e7490); }
.pp-ct-info .row.adr .ic { background:linear-gradient(135deg,#7c3aed,#5b21b6); }
.pp-ct-info .row.hr .ic { background:linear-gradient(135deg,#f59e0b,#d97706); }
.pp-ct-info .row b { display:block; color:#0f172a; font-size:14px; margin-bottom:2px; }
.pp-ct-info .row span { color:#64748b; font-size:13px; line-height:1.55; }
.pp-ct-form .field { margin-bottom:14px; }
.pp-ct-form label { display:block; color:#475569; font-size:13px; font-weight:600; margin-bottom:6px; }
.pp-ct-form input, .pp-ct-form textarea { width:100%; padding:11px 14px; border:1px solid #e2e8f0; border-radius:10px; font-size:14px; outline:0; transition:.2s; font-family:inherit; }
.pp-ct-form input:focus, .pp-ct-form textarea:focus { border-color:#15803d; box-shadow:0 0 0 3px #dcfce7; }
.pp-ct-form button { width:100%; background:linear-gradient(135deg,#22c55e,#15803d); color:#fff; border:0; padding:13px 20px; border-radius:10px; font-weight:700; cursor:pointer; font-size:14px; }
.pp-ct-form button:hover { transform:translateY(-1px); box-shadow:0 8px 20px rgba(21,128,61,.3); }

/* ===================== pp-legal (Syarat/Privasi — slate) ===================== */
body.pp-legal .pp-sec .h-cap .ey { color:#475569; background:#f1f5f9; }
body.pp-legal .grad { background:linear-gradient(135deg,#0f172a,#475569); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-legal-doc { max-width:860px; margin:0 auto; background:#fff; border:1px solid #e5e7eb; border-radius:18px; padding:36px 38px; box-shadow:0 10px 30px rgba(0,0,0,.04); }
.pp-legal-doc .toc { background:#f8fafc; border-left:3px solid #0f172a; padding:14px 18px; border-radius:6px; margin-bottom:24px; }
.pp-legal-doc .toc b { display:block; color:#0f172a; font-size:13px; margin-bottom:6px; }
.pp-legal-doc .toc a { display:inline-block; color:#475569; font-size:13px; text-decoration:none; margin:2px 14px 2px 0; transition:.2s; }
.pp-legal-doc .toc a:hover { color:#0f172a; text-decoration:underline; }
.pp-legal-doc h3 { color:#0f172a; font-weight:800; font-size:18px; margin:24px 0 10px; padding-top:8px; }
.pp-legal-doc h3:first-child { margin-top:0; padding-top:0; }
.pp-legal-doc p { color:#334155; font-size:14.5px; line-height:1.75; margin:0 0 12px; }
.pp-legal-doc ul { color:#334155; font-size:14.5px; line-height:1.75; padding-left:22px; margin:0 0 14px; }
.pp-legal-doc ul li { margin-bottom:4px; }
.pp-legal-doc .meta { color:#94a3b8; font-size:13px; padding-bottom:18px; border-bottom:1px dashed #e5e7eb; margin-bottom:22px; }

/* ===================== pp-promo (Hosting Murah — orange/red, reuse pp-promo) ===================== */
body.pp-cheap .pp-stat-strip .it .ic { background:#fee2e2; color:#dc2626; }
body.pp-cheap .pp-sec .h-cap .ey { color:#dc2626; background:#fee2e2; }
body.pp-cheap .idc-price.featured { border-color:#dc2626; }
body.pp-cheap .idc-price .cta { background:linear-gradient(135deg,#f97316,#dc2626); color:#fff; }
body.pp-cheap .idc-price .badge-popular { background:#dc2626; }
body.pp-cheap .pp-tiles .card .ic { background:#fee2e2; color:#dc2626; }
body.pp-cheap .idc-cta-banner { background:linear-gradient(135deg,#7f1d1d,#dc2626); }
body.pp-cheap .grad { background:linear-gradient(135deg,#dc2626,#f97316); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pp-save-bar { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:14px; margin-top:24px; }
.pp-save-bar .b { background:#fff; border:2px dashed #fecaca; border-radius:14px; padding:20px; text-align:center; }
.pp-save-bar .b .lb { color:#dc2626; font-weight:800; font-size:14px; }
.pp-save-bar .b .vl { color:#0f172a; font-size:24px; font-weight:800; margin-top:4px; }
.pp-save-bar .b .ds { color:#64748b; font-size:12px; margin-top:4px; }
