/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --orange:#FF2D7A;--orange2:#FF7A00;--orange-light:#fff0f5;--orange-mid:#ffc0d4;
  --blue:#2596be;--blue2:#1a7a9e;--blue-light:#e8f6fb;
  --teal:#0ea5e9;--teal-light:#f0f9ff;--teal2:#0284c7;
  --green:#22c55e;--green-light:#f0fdf4;
  --red:#ef4444;--red2:#dc2626;
  --ink:#1A0033;--ink2:#374151;--ink3:#6b7280;--ink4:#9ca3af;
  --surface:#f9fafb;--surface2:#f3f4f6;
  --white:#ffffff;--border:#e5e7eb;--border2:#d1d5db;
  --font:'Plus Jakarta Sans',sans-serif;
  --shadow2:0 4px 24px rgba(0,0,0,0.1);
  --shadow3:0 20px 60px rgba(0,0,0,0.14);
  /* UPDATE: Padding minimal diperbesar dari 16px ke 24px agar tidak nabrak */
  --px:clamp(24px,5vw,40px);
  --spy:clamp(48px,8vw,80px);
}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  overflow-x: clip; /* UPDATE: Kunci luapan X */
  width: 100%;
  max-width: 100vw;
}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--white);
  font-size:16px;
  line-height:1.6;
  overflow-x:clip; /* UPDATE: Kunci luapan X */
  width: 100%;
  max-width: 100vw;
  position: relative;
}


a{text-decoration:none;color:inherit;}
.container{max-width:1080px;margin:0 auto;padding:0 var(--px);}
.container-sm{max-width:720px;margin:0 auto;padding:0 var(--px);}
.container-md{max-width:900px;margin:0 auto;padding:0 var(--px);}

/* ── BUTTON HOVER SYSTEM (global) ── */
.btn-primary,.btn-hero,.btn-form,.nav-cta,.pb-cta,.sticky-btn{
  transition:transform 0.18s ease,box-shadow 0.18s ease,background 0.18s ease,opacity 0.18s ease;
}
.btn-primary:hover,.btn-hero:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(255,45,122,0.38);}
.btn-form:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,45,122,0.4);}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(255,45,122,0.3);}
.pb-cta:hover{opacity:0.88;transform:translateY(-1px);}
.sticky-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,45,122,0.4);}

/* ── NAV ── */
nav{background:var(--white);border-bottom:1px solid var(--border);padding:0 var(--px);height:68px;display:flex;align-items:center;position:sticky;top:0;z-index:200;box-shadow:0 1px 8px rgba(0,0,0,0.06);}
.nav-inner{max-width:1080px;margin:0 auto;width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.nav-logo-badge{background:var(--orange);color:white;font-size:12px;font-weight:800;padding:5px 10px;border-radius:6px;letter-spacing:1px;}
.nav-logo-name{font-size:14px;font-weight:800;color:var(--ink);line-height:1.15;}
.nav-logo-tagline{font-size:10px;font-weight:500;color:var(--ink3);}
.nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.nav-countdown{display:flex;align-items:center;gap:5px;}
.nav-cd-label{font-size:10px;color:var(--ink3);font-weight:500;white-space:nowrap;}
.nav-cd-blocks{display:flex;align-items:center;gap:2px;}
.nav-cd-block{display:flex;flex-direction:column;align-items:center;background:var(--ink);border-radius:4px;padding:3px 6px;min-width:30px;}
.nav-cd-num{font-size:13px;font-weight:800;color:var(--orange);line-height:1;}
.nav-cd-unit{font-size:6.5px;color:rgba(255,255,255,0.45);margin-top:1px;letter-spacing:0.4px;}
.nav-cd-sep{font-size:13px;font-weight:700;color:var(--ink4);}
.nav-cta{background:var(--orange);color:white;font-size:13px;font-weight:700;padding:9px 18px;border-radius:8px;white-space:nowrap;}

/* ── PROMO BANNER ── */
.promo-banner{background:var(--orange);padding:10px var(--px);text-align:center;}
.promo-banner-inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;}
.pb-badge{background:rgba(255,255,255,0.2);color:white;font-size:10px;font-weight:700;padding:2px 9px;border-radius:20px;}
.pb-text{font-size:13px;font-weight:600;color:white;}
.pb-cta{background:white;color:var(--orange2);font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;}

/* ── HERO ── */
.hero{background:linear-gradient(155deg,#fff5f8 0%,var(--white) 55%);padding:clamp(48px,7vw,80px) var(--px) clamp(48px,7vw,72px);border-bottom:1px solid var(--border);}
.hero-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:center;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:7px;background:var(--orange-light);border:1px solid var(--orange-mid);border-radius:20px;padding:4px 12px;margin-bottom:20px;font-size:11px;font-weight:600;color:var(--orange2);}
.hero-eyebrow-dot{width:6px;height:6px;background:var(--orange);border-radius:50%;animation:blink 1.5s infinite;flex-shrink:0;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.hero-title{font-size:clamp(28px,4.5vw,50px);font-weight:800;color:var(--ink);line-height:1.12;letter-spacing:-0.5px;margin-bottom:16px;}
.hero-title .highlight{color:var(--orange);}
.hero-sub{font-size:clamp(14px,2vw,16px);color:var(--ink2);line-height:1.7;margin-bottom:28px;max-width:460px;}
.hero-sub strong{color:var(--ink);font-weight:600;}
.btn-hero{background:var(--orange);color:white;font-size:clamp(14px,2vw,15px);font-weight:700;padding:14px 32px;border-radius:10px;border:none;cursor:pointer;font-family:var(--font);display:inline-block;box-shadow:0 4px 20px rgba(255,45,122,0.35);}
.hero-img-wrap{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow3);border:1px solid var(--border);}
.hero-img-main{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#f1f5f9,#e2e8f0,#cbd5e1);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;}
/* Local PNG hero image */
.hero-img-local{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;object-position:center top;border-radius:0;}
.him-icon{font-size:clamp(36px,6vw,52px);opacity:0.28;}
.him-label{font-size:12px;font-weight:600;color:var(--ink4);}
.hero-stat-card{position:absolute;background:white;border-radius:10px;padding:9px 13px;box-shadow:0 4px 20px rgba(0,0,0,0.12);border:1px solid var(--border);}
.hsc-top{left:14px;top:16px;}
.hsc-bottom{right:14px;bottom:16px;}
.hsc-label{font-size:8.5px;font-weight:600;color:var(--ink4);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:2px;}
.hsc-value{font-size:17px;font-weight:800;color:var(--orange);line-height:1;}
.hsc-sub{font-size:9.5px;color:var(--ink3);margin-top:2px;}
.hsc-green .hsc-value{color:var(--green);}

/* ── SECTIONS ── */
.section{padding:var(--spy) var(--px);}
.section-alt{background:var(--surface);}
.section-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--teal2);background:var(--teal-light);border:1px solid #bae6fd;padding:4px 12px;border-radius:20px;margin-bottom:14px;letter-spacing:0.5px;text-transform:uppercase;}
.section-title{font-size:clamp(22px,4vw,34px);font-weight:800;color:var(--ink);line-height:1.2;letter-spacing:-0.3px;margin-bottom:12px;}
.section-title .accent{color:var(--orange);}
.section-desc{font-size:clamp(14px,2vw,16px);color:var(--ink2);line-height:1.65;}

/* ── PAIN CARDS ── */
.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px;}
.pain-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:clamp(18px,3vw,28px);transition:transform 0.2s,box-shadow 0.2s;position:relative;overflow:hidden;}
.pain-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),#f87171);}
.pain-card:hover{transform:translateY(-3px);box-shadow:var(--shadow2);}
.pain-num{font-size:10px;font-weight:600;color:var(--ink4);letter-spacing:1px;margin-bottom:8px;}
.pain-icon{font-size:26px;margin-bottom:12px;}
.pain-title{font-size:clamp(14px,2vw,16px);font-weight:700;color:var(--ink);margin-bottom:6px;}
.pain-desc{font-size:13px;color:var(--ink3);line-height:1.65;}

/* ── FEATURE VISUAL (tables) ── */
.feature-visual{background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow2);}
.fv-header{background:var(--surface2);padding:11px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.fv-title{font-size:12px;font-weight:600;color:var(--ink2);}
.fv-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;background:var(--green-light);color:var(--green);}
.fv-badge.orange{background:var(--orange-light);color:var(--orange2);}

/* CMP TABLE — blue standout col */
.cmp-table{width:100%;border-collapse:collapse;font-size:12.5px;}
.cmp-table th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;}
.cmp-table th:first-child{background:var(--surface2);color:var(--ink3);}
.cmp-table th.col-bad{background:#fff1f1;color:var(--red);text-align:center;}
.cmp-table th.col-good{background:var(--blue);color:white;text-align:center;}
.cmp-table td{padding:10px 14px;border-bottom:1px solid var(--surface2);}
.cmp-table tr:last-child td{border-bottom:none;}
.cmp-table td:first-child{font-weight:500;color:var(--ink2);}
.cmp-table td.col-bad{color:var(--red);text-align:center;background:#fffafa;}
.cmp-table td.col-good{color:white;font-weight:700;text-align:center;background:var(--blue);}
.saving-note{padding:11px 14px;background:var(--orange-light);border-top:1px solid var(--orange-mid);font-size:12px;color:var(--ink2);}
.saving-note strong{color:var(--orange2);font-weight:700;}

/* WHY TABLE — blue standout col */
.why-table{width:100%;border-collapse:collapse;font-size:12px;}
.why-table th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;}
.why-table th:first-child{background:var(--surface2);color:var(--ink3);}
.why-table th.col-bad{background:#fff1f1;color:var(--red);}
.why-table th.col-good{background:var(--blue);color:white;}
.why-table td{padding:10px 14px;border-bottom:1px solid var(--surface2);}
.why-table tr:last-child td{border-bottom:none;}
.why-table td:first-child{font-weight:500;color:var(--ink2);}
.why-table td.col-bad{color:var(--red);background:#fffafa;}
.why-table td.col-good{color:white!important;font-weight:600;background:var(--blue);}
/* Fix hover: override any hover color change on blue cells */
.why-table tr:hover td.col-good{color:white!important;background:var(--blue2);}
.why-table tr:hover td.col-bad{background:#fff0f0;}
.why-table tr:hover td:first-child{background:var(--surface);}

/* ── FEATURES GRID ── */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px;}
.feat-card{border-radius:14px;padding:clamp(18px,3vw,24px);transition:transform 0.2s,box-shadow 0.2s;position:relative;border:1px solid var(--border);background:var(--white);}
.feat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow2);}
/* Dark variant only for chatbot AI (#8) and support 12 bulan (#9) */
.feat-card.dark{background:var(--ink);border-color:var(--ink);}
.feat-card.dark .feat-name{color:white;}
.feat-card.dark .feat-desc{color:rgba(255,255,255,0.6);}
.feat-card .new-badge{position:absolute;top:14px;right:14px;font-size:9px;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--orange);color:white;}
.feat-card .new-badge.teal-badge{background:var(--teal2);}
.feat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:19px;margin-bottom:12px;}
.fi-orange{background:var(--orange-light);}
.fi-teal{background:var(--teal-light);}
.fi-green{background:var(--green-light);}
.fi-dark{background:rgba(255,255,255,0.1);}
.feat-name{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:5px;}
.feat-desc{font-size:13px;color:var(--ink3);line-height:1.6;}

/* ── PORTFOLIO ── */
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--border);border-radius:16px;overflow:hidden;border:1px solid var(--border);}
.port-card{background:var(--white);transition:box-shadow 0.2s;overflow:hidden;cursor:pointer;}
.port-card:hover .port-img-inner{transform:scale(1.05);}
.port-card.large{grid-column:span 2;}
.port-img{overflow:hidden;}
.port-img-inner{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;transition:transform 0.4s ease;position:relative;}
.port-card.large .port-img-inner{aspect-ratio:2/1;}
.port-card:nth-child(1) .port-img-inner{background:linear-gradient(135deg,#fdf2f8,#fce7f3,#f9a8d4);}
.port-card:nth-child(2) .port-img-inner{background:linear-gradient(135deg,#f0fdf4,#dcfce7,#86efac);}
.port-card:nth-child(3) .port-img-inner{background:linear-gradient(135deg,#fff0f5,#ffc0d4,#fb923c);}
.port-card:nth-child(4) .port-img-inner{background:linear-gradient(135deg,#eff6ff,#dbeafe,#93c5fd);}
.port-card:nth-child(5) .port-img-inner{background:linear-gradient(135deg,#fefce8,#fef08a,#facc15);}
.port-shape{position:absolute;border-radius:50%;pointer-events:none;}
.ps-a{width:90px;height:90px;top:-25px;right:-25px;opacity:0.35;}
.ps-b{width:55px;height:55px;bottom:14px;left:14px;opacity:0.35;}
.ps-c{width:140px;height:140px;bottom:-55px;right:-40px;opacity:0.12;}
.port-card:nth-child(1) .ps-a,.port-card:nth-child(1) .ps-b,.port-card:nth-child(1) .ps-c{background:#ec4899;}
.port-card:nth-child(2) .ps-a,.port-card:nth-child(2) .ps-b,.port-card:nth-child(2) .ps-c{background:#22c55e;}
.port-card:nth-child(3) .ps-a,.port-card:nth-child(3) .ps-b,.port-card:nth-child(3) .ps-c{background:#FF2D7A;}
.port-card:nth-child(4) .ps-a,.port-card:nth-child(4) .ps-b,.port-card:nth-child(4) .ps-c{background:#3b82f6;}
.port-card:nth-child(5) .ps-a,.port-card:nth-child(5) .ps-b,.port-card:nth-child(5) .ps-c{background:#eab308;}
.port-icon{font-size:40px;position:relative;z-index:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,0.1));}
.port-body{padding:16px 18px;border-top:1px solid var(--border);}
.port-name{font-size:16px;font-weight:800;color:var(--ink);}
.port-stat{display:block;font-size:12px;font-weight:600;color:var(--green);margin-top:4px;}

/* Real image in portfolio card */
.port-real-img{width:100%;height:100%;object-fit:cover;object-position:center top;position:absolute;inset:0;}
.port-img-inner{position:relative;}
.port-fallback{width:100%;height:100%;position:absolute;inset:0;display:flex;align-items:center;justify-content:center;}

/* +50 klien card */
.port-more-inner{background:linear-gradient(135deg,#1A0033,#2d0060);flex-direction:column;gap:8px;}
.port-more-number{font-size:clamp(36px,6vw,52px);font-weight:900;color:white;line-height:1;position:relative;z-index:1;}
.port-more-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);position:relative;z-index:1;}
.port-more-label{font-size:13px;font-weight:600;color:rgba(255,255,255,0.6);position:relative;z-index:1;text-align:center;line-height:1.4;}

/* ── WA CAROUSEL (apa kata mereka) — horizontal loop ── */
.wa-carousel-wrap{margin-top:36px;position:relative;overflow:hidden;}
/* Fade left/right */
.wa-carousel-wrap::before,.wa-carousel-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.wa-carousel-wrap::before{left:0;background:linear-gradient(to right,var(--surface),transparent);}
.wa-carousel-wrap::after{right:0;background:linear-gradient(to left,var(--surface),transparent);}
/* Track */
.wa-track{
  display:flex;
  flex-direction:row;
  gap:16px;
  width:max-content;
  animation:wa-scroll-h 32s linear infinite;
}
.wa-track:hover{animation-play-state:paused;}
@keyframes wa-scroll-h{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}
/* Portrait card — 9:16 */
.wa-card{
  flex-shrink:0;
  width:220px;
  aspect-ratio:9/16;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 4px 20px rgba(0,0,0,0.10);
  background:#e2e8f0;
}
.wa-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top;
  display:block;
}
@media(max-width:680px){.wa-card{width:160px;}}

/* ── GUARANTEE ── */
.guarantee{background:linear-gradient(135deg,#1A0033 0%,#3d0080 100%);padding:var(--spy) var(--px);text-align:center;}
.guarantee-badge{width:90px;height:90px;margin:0 auto 28px;background:linear-gradient(135deg,var(--orange),#FF7A00);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(255,45,122,0.4);}
.gb-num{font-size:22px;font-weight:900;color:white;line-height:1;}
.gb-text{font-size:7.5px;font-weight:700;color:rgba(255,255,255,0.9);letter-spacing:1px;text-align:center;margin-top:2px;}
.guarantee-title{font-size:clamp(20px,4vw,32px);font-weight:800;color:white;margin-bottom:14px;}
.guarantee-desc{font-size:clamp(14px,2vw,16px);color:rgba(255,255,255,0.7);max-width:520px;margin:0 auto 36px;line-height:1.65;}

/* ── FAQ ── */
.faq-list{border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-top:36px;}
.faq-item{border-bottom:1px solid var(--border);}
.faq-item:last-child{border-bottom:none;}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;cursor:pointer;font-size:clamp(13px,2vw,15px);font-weight:600;color:var(--ink);transition:background 0.15s;gap:12px;}
.faq-q:hover{background:var(--surface);}
.faq-arrow{font-size:20px;color:var(--orange);transition:transform 0.2s;flex-shrink:0;}
.faq-a{display:none;padding:0 22px 16px;font-size:14px;color:var(--ink2);line-height:1.7;}
.faq-item.open .faq-a{display:block;}
.faq-item.open .faq-arrow{transform:rotate(45deg);}

/* ── FINAL FORM SECTION ── */
.final-section{padding:var(--spy) var(--px);background:linear-gradient(180deg,var(--surface) 0%,var(--white) 100%);}
.form-header{text-align:center;margin-bottom:28px;}
.fh-eyebrow{font-size:11px;font-weight:600;color:var(--orange2);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;}
.fh-title{font-size:clamp(22px,4vw,32px);font-weight:800;color:var(--ink);margin-bottom:6px;letter-spacing:-0.3px;}
.fh-title .accent{color:var(--orange);}
.fh-price-row{display:flex;align-items:center;justify-content:center;gap:12px;margin:14px 0 6px;flex-wrap:wrap;}
.fh-price-old{font-size:18px;font-weight:600;color:var(--ink3);text-decoration:line-through;}
.fh-price-new{font-size:clamp(28px,5vw,38px);font-weight:900;color:var(--orange);line-height:1;}
/* RED discount badge */
.fh-discount-badge{background:var(--red2);color:white;font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;animation:badge-pulse 1.8s ease-in-out infinite;}
@keyframes badge-pulse{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(220,38,38,0.4);}50%{transform:scale(1.05);box-shadow:0 0 0 6px rgba(220,38,38,0);}}
.fh-note{font-size:13px;color:var(--ink3);margin-bottom:14px;}
/* Form card */
.final-cta-card{max-width:580px;margin:28px auto 0;background:var(--white);border:2px solid var(--orange);border-radius:20px;padding:clamp(24px,5vw,44px);box-shadow:0 8px 40px rgba(255,45,122,0.12);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:10px;}
.form-group.full{grid-column:1/-1;}
.form-label{font-size:12px;font-weight:600;color:var(--ink2);}
.form-input,.form-select{width:100%;padding:11px 14px;border:1.5px solid var(--border2);border-radius:8px;font-size:14px;font-family:var(--font);color:var(--ink);background:var(--surface);transition:border-color 0.15s;outline:none;}
.form-input:focus,.form-select:focus{border-color:var(--orange);background:var(--white);}
.form-input::placeholder{color:var(--ink4);}
.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;}
.btn-form{width:100%;background:var(--orange);color:white;font-size:16px;font-weight:700;padding:15px;border-radius:10px;border:none;cursor:pointer;font-family:var(--font);box-shadow:0 4px 20px rgba(255,45,122,0.35);margin-top:8px;}

/* ── FOOTER — fixed, no glitch boxes ── */
footer{background:#1A0033;padding:clamp(36px,6vw,48px) var(--px) clamp(24px,4vw,32px);color:rgba(255,255,255,0.4);}
.footer-grid{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(20px,4vw,40px);padding-bottom:clamp(28px,4vw,40px);border-bottom:1px solid rgba(255,255,255,0.08);margin-bottom:clamp(18px,3vw,24px);}
.footer-brand-name{font-size:17px;font-weight:800;color:var(--orange);margin-bottom:3px;}
.footer-brand-sub{font-size:9px;font-weight:600;letter-spacing:2px;color:rgba(255,255,255,0.3);text-transform:uppercase;margin-bottom:10px;}
.footer-brand-desc{font-size:13px;line-height:1.65;color:rgba(255,255,255,0.38);}
.footer-col-title{font-size:11px;font-weight:700;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:12px;}
.footer-link-list{display:flex;flex-direction:column;gap:8px;}
.footer-link{font-size:13px;color:rgba(255,255,255,0.38);transition:color 0.15s;display:block;}
.footer-link:hover{color:var(--orange);}
.footer-col{display:block;}
.footer-bottom-row{max-width:1080px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.28);}

/* ── MOBILE STICKY BAR ── */
.sticky-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:300;
  background:var(--white);border-top:1px solid var(--border);
  padding:10px 16px 12px;
  box-shadow:0 -4px 20px rgba(0,0,0,0.12);
  flex-direction:column;align-items:center;gap:8px;
}
.sticky-cd{display:flex;align-items:center;gap:6px;}
.sticky-cd-label{font-size:10px;color:var(--ink3);font-weight:500;}
.sticky-cd-blocks{display:flex;align-items:center;gap:2px;}
.sticky-cd-block{display:flex;flex-direction:column;align-items:center;background:var(--ink);border-radius:4px;padding:3px 6px;min-width:28px;}
.sticky-cd-num{font-size:13px;font-weight:800;color:var(--orange);line-height:1;}
.sticky-cd-unit{font-size:6px;color:rgba(255,255,255,0.45);margin-top:1px;}
.sticky-cd-sep{font-size:12px;font-weight:700;color:var(--ink4);}
.sticky-btn{background:var(--orange);color:white;font-size:14px;font-weight:700;padding:12px;border-radius:10px;border:none;cursor:pointer;font-family:var(--font);box-shadow:0 4px 16px rgba(255,45,122,0.35);}

/* ── ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 0.55s ease,transform 0.55s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-d1{transition-delay:0.07s;}.reveal-d2{transition-delay:0.14s;}.reveal-d3{transition-delay:0.21s;}
@keyframes floatUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.hero-eyebrow{animation:floatUp 0.5s ease both;}
.hero-title{animation:floatUp 0.5s 0.07s ease both;}
.hero-sub{animation:floatUp 0.5s 0.14s ease both;}
.hero-actions{animation:floatUp 0.5s 0.2s ease both;}
.hero-right{animation:floatUp 0.6s 0.16s ease both;}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;}
  .wa-card{width:280px;}
}
@media(max-width:768px){
  :root{--px:20px;--spy:52px;}
  .hero-inner{grid-template-columns:1fr;gap:36px;}
  .hero-right{order:-1;}
  .hero-sub{max-width:100%;}
  .pain-grid{grid-template-columns:1fr 1fr;}
  .feat-grid{grid-template-columns:1fr 1fr;}
  .portfolio-grid{grid-template-columns:1fr 1fr;}
  .port-card.large{grid-column:span 2;}
  .port-card.large .port-img-inner{aspect-ratio:4/3;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .nav-countdown{display:none;}
  /* Mobile: promo banner hidden */
  .promo-banner{display:none;}
  /* Mobile: nav CTA hidden */
  .nav-cta{display:none;}
  /* Mobile sticky bar show */
  .sticky-bar{display:none}
  /* Mobile bottom padding so content not hidden behind sticky */
  body{padding-bottom:90px;}
  .wa-card{width:260px;}
}
@media(max-width:599px){
  :root{--px:16px;--spy:44px;}
  .pain-grid,.feat-grid{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:1fr;}
  .port-card.large{grid-column:span 1;}
  .port-card.large .port-img-inner{aspect-ratio:4/3;}
  .footer-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .form-group.full{grid-column:1;}
  .fh-price-row{flex-direction:column;align-items:center;gap:6px;}
  .fh-countdown{flex-wrap:wrap;justify-content:center;}
  nav{height:60px;}
  .wa-card{width:240px;}
}
/* ── BONUS CHECKLIST CARDS ── */
.fh-bonus-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:14px;margin:24px 0 18px;text-align:left;
}
.fh-bonus-card{
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:14px;padding:18px 16px;
  position:relative;overflow:hidden;
  transition:transform 0.2s,box-shadow 0.2s;
}
.fh-bonus-card:hover{transform:translateY(-2px);box-shadow:var(--shadow2);}
.fh-bonus-card--mid{
  border-color:var(--orange);
  box-shadow:0 4px 20px rgba(255,45,122,0.12);
}
.fh-bonus-card--mid::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--orange),var(--orange2));
}
.fh-bonus-icon{font-size:22px;margin-bottom:8px;}
.fh-bonus-title{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:5px;}
.fh-bonus-desc{font-size:12px;color:var(--ink3);line-height:1.55;margin-bottom:10px;}
.fh-bonus-tag{
  display:inline-block;font-size:9px;font-weight:800;
  padding:2px 9px;border-radius:20px;letter-spacing:0.8px;
  background:var(--orange);color:white;
}
.fh-bonus-card--mid .fh-bonus-tag{background:var(--orange2);}

/* ── STANDOUT COUNTDOWN ── */
.fh-countdown-wrap{
  margin-top:20px;
  background:#0d0020;
  border:1px solid rgba(255,45,122,0.25);
  border-radius:14px;
  padding:16px 24px;
  display:inline-block;
  position:relative;overflow:hidden;
}
.fh-countdown-wrap::before{
  content:'';position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:260px;height:80px;
  background:radial-gradient(ellipse,rgba(255,45,122,0.07) 0%,transparent 70%);
  pointer-events:none;
}
.fh-cd-header{
  display:flex;align-items:center;gap:7px;
  justify-content:center;margin-bottom:12px;
}
.fh-cd-pulse{
  width:7px;height:7px;border-radius:50%;
  background:var(--orange);flex-shrink:0;
  animation:cdpulse 2s ease-in-out infinite;
}
@keyframes cdpulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,45,122,0.4);opacity:1;}
  50%{box-shadow:0 0 0 5px rgba(255,45,122,0);opacity:0.75;}
}
.fh-cd-title{
  font-size:11px;font-weight:600;
  color:rgba(255,255,255,0.45);
  letter-spacing:0.8px;text-transform:uppercase;
}
.fh-countdown{
  display:flex;align-items:center;gap:7px;
  justify-content:center;
}
.fh-cd-block{
  display:flex;flex-direction:column;align-items:center;
  background:rgba(255,45,122,0.08);
  border:1px solid rgba(255,45,122,0.2);
  border-radius:8px;padding:8px 14px;min-width:48px;
}
.fh-cd-num{
  font-size:22px;font-weight:800;
  color:var(--orange);line-height:1;
  font-variant-numeric:tabular-nums;
}
.fh-cd-unit{
  font-size:8px;color:rgba(255,255,255,0.3);
  margin-top:3px;letter-spacing:0.8px;
}
.fh-cd-sep{
  font-size:18px;font-weight:700;
  color:rgba(255,45,122,0.3);line-height:1;
  margin-bottom:14px;
}

@media(max-width:599px){
  .fh-countdown-wrap{padding:13px 16px;}
  .fh-cd-block{min-width:40px;padding:7px 10px;}
  .fh-cd-num{font-size:18px;}
  .fh-cd-sep{font-size:15px;}
}

/* ── FITUR CARDS ── */
.fitur-cards-wrap{margin-top:36px;position:relative;}
/* Desktop: 3-col grid */
.fitur-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
/* Mobile: horizontal scroll carousel */
@media(max-width:680px){
  .fitur-cards-grid{
    display:flex;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    gap:12px;
    padding-bottom:16px;
    scrollbar-width:none;
  }
  .fitur-cards-grid::-webkit-scrollbar{display:none;}
  .fitur-card{
    flex:0 0 82vw;
    max-width:300px;
    scroll-snap-align:start;
  }
}
.fitur-card{
  border-radius:16px;
  border:1px solid var(--border);
  background:var(--white);
  overflow:hidden;
  transition:transform 0.2s,box-shadow 0.2s;
  display:flex;
  flex-direction:column;
}
.fitur-card:hover{transform:translateY(-3px);box-shadow:var(--shadow2);}
.fitur-card.bonus-card{border-color:var(--orange-mid);background:var(--orange-light);}
/* Icon box (replaces image placeholder) */
.fitur-card-img{
  width:100%;
  padding:28px 0 20px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  position:relative;
}
.fitur-card-img .fitur-icon-wrap{
  width:64px;height:64px;
  border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  font-size:30px;
  box-shadow:0 4px 16px rgba(0,0,0,0.10);
  position:relative;z-index:1;
}
/* Subtle radial glow behind icon */
.fitur-card-img::before{
  content:'';position:absolute;inset:0;
  border-radius:0;
  opacity:0.55;
}
/* Per-card icon bg colours */
.fitur-card:nth-child(1) .fitur-card-img{background:linear-gradient(135deg,#f5f3ff,#ede9fe);}
.fitur-card:nth-child(1) .fitur-icon-wrap{background:#7c3aed;color:white;}
.fitur-card:nth-child(2) .fitur-card-img{background:linear-gradient(135deg,#f0fdf4,#dcfce7);}
.fitur-card:nth-child(2) .fitur-icon-wrap{background:#16a34a;color:white;}
.fitur-card:nth-child(3) .fitur-card-img{background:linear-gradient(135deg,#eff6ff,#dbeafe);}
.fitur-card:nth-child(3) .fitur-icon-wrap{background:#2563eb;color:white;}
.fitur-card:nth-child(4) .fitur-card-img{background:linear-gradient(135deg,#fefce8,#fef9c3);}
.fitur-card:nth-child(4) .fitur-icon-wrap{background:#ca8a04;color:white;}
.fitur-card:nth-child(5) .fitur-card-img{background:linear-gradient(135deg,#fff1f2,#ffe4e6);}
.fitur-card:nth-child(5) .fitur-icon-wrap{background:#e11d48;color:white;}
.fitur-card:nth-child(6) .fitur-card-img{background:linear-gradient(135deg,#f0fdfa,#ccfbf1);}
.fitur-card:nth-child(6) .fitur-icon-wrap{background:#0d9488;color:white;}
/* Bonus cards (7, 8, 9) */
.fitur-card:nth-child(7) .fitur-card-img,
.fitur-card:nth-child(8) .fitur-card-img,
.fitur-card:nth-child(9) .fitur-card-img{background:linear-gradient(135deg,#fff0f5,#ffedd5);}
.fitur-card:nth-child(7) .fitur-icon-wrap,
.fitur-card:nth-child(8) .fitur-icon-wrap,
.fitur-card:nth-child(9) .fitur-icon-wrap{background:var(--orange);color:white;}
.fitur-card-body{padding:14px 16px 16px;flex:1;display:flex;flex-direction:column;gap:6px;}
.fitur-card-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--ink4);}
.fitur-card.bonus-card .fitur-card-label{color:var(--orange2);}
.fitur-card-name{font-size:14px;font-weight:700;color:var(--ink);line-height:1.3;}
.fitur-card.bonus-card .fitur-card-name{color:var(--orange2);}
.fitur-card-desc{font-size:12px;color:var(--ink3);line-height:1.6;flex:1;}
.fitur-card-badge{margin-top:10px;display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;color:var(--green);background:var(--green-light);border:1px solid #bbf7d0;padding:3px 10px;border-radius:20px;align-self:flex-start;}
.fitur-card.bonus-card .fitur-card-badge{color:var(--orange2);background:white;border-color:var(--orange-mid);}
/* Mobile scroll dots */
.fitur-dots{display:none;justify-content:center;gap:5px;margin-top:12px;}
@media(max-width:680px){.fitur-dots{display:flex;}}
.fitur-dot{width:6px;height:6px;border-radius:50%;background:var(--border2);transition:background 0.2s,width 0.2s;}
.fitur-dot.active{background:var(--orange);width:16px;border-radius:3px;}
/* Swipe hint label */
.fitur-swipe-hint{display:none;text-align:center;font-size:11px;color:var(--ink4);margin-top:6px;}
@media(max-width:680px){.fitur-swipe-hint{display:block;}}

/* ═══════════════════════════════════════════════════
   TESTIMONI CARD GRID
   ═══════════════════════════════════════════════════ */
.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 40px;
}

.testi-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.testi-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow3);
  border-color: var(--orange-mid);
}

.testi-quote {
  font-family: Georgia, serif;
  font-size: 3.5rem;
  font-weight: 900;
  color: var(--orange);
  line-height: 0.8;
  opacity: 0.35;
  flex-shrink: 0;
  user-select: none;
}

.testi-text {
  font-size: 14px;
  color: var(--ink2);
  line-height: 1.75;
  flex: 1;
}

.testi-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  margin-top: auto;
}

.testi-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--orange), var(--orange2));
  color: white;
  font-size: 13px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: 0.5px;
}

.testi-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.3;
}

.testi-company {
  font-size: 12px;
  color: var(--ink3);
  margin-top: 2px;
}

/* ═══════════════════════════════════════════════════
   CLIENT LOGO GRID  (10 logo + 1 card 50+)
   ═══════════════════════════════════════════════════ */
.client-logo-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
  margin-bottom: 48px;
  justify-items: center;
  place-items: center;
}

.client-logo-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 18px;
  overflow: hidden;
  transition: border-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}

.client-logo-card:hover {
  border-color: var(--orange-mid);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
}

/* Logo image */
.client-logo-card img {
  max-height: 36px;
  width: auto;
  object-fit: contain;
  filter: grayscale(1) opacity(0.55);
  transition: filter 0.3s ease;
  pointer-events: none;
}

.client-logo-card:hover img {
  filter: grayscale(0) opacity(1);
}

/* +50 Client Lainnya card */
.client-logo-more {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-style: dashed;
  border-color: var(--orange-mid);
  background: var(--orange-light);
  flex-direction: column;
  gap: 3px;
  cursor: default;
}

.client-logo-more:hover {
  transform: none;
  box-shadow: none;
  border-color: var(--orange);
}

.clm-num {
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--orange);
  line-height: 1;
}

.clm-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--ink3);
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .testi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .client-logo-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (max-width: 640px) {
  .testi-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .client-logo-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }
  .client-logo-card {
    height: 68px;
    padding: 10px 12px;
  }
  .client-logo-card img {
    max-height: 28px;
  }
  .testi-card {
    padding: 22px 18px;
  }
  .testi-text {
    font-size: 13.5px;
  }
}


}

/* ════════════════════════════════════════════
   FITUR TOKO ONLINE — 3D CAROUSEL
   Card active: zoom-in center
   Cards inactive: scaled-down behind, sides
════════════════════════════════════════════ */

.ftr-stage {
  position: relative;
  width: 100%;
  padding: 40px 0 24px;
  overflow: hidden;        /* clips side cards */
  perspective: 1200px;     /* 3D depth */
}

/* Track: lays cards side by side in 3D space */
.ftr-track {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  height: 340px;           /* card height */
  width: 100%;
}

/* ── Base card ── */
.ftr-card {
  position: absolute;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  width: min(700px, 88vw);
  height: 300px;
  border-radius: 20px;
  overflow: hidden;
  background: var(--white);
  border: 1.5px solid var(--border);
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
  cursor: pointer;
  /* Default: invisible and pushed back */
  opacity: 0;
  transform: translateX(0) scale(0.72) translateZ(-200px);
  transition:
    transform  0.55s cubic-bezier(0.25,0.46,0.45,0.94),
    opacity    0.45s ease,
    box-shadow 0.45s ease,
    z-index    0s;
  pointer-events: none;
  will-change: transform, opacity;
}

/* ── ACTIVE: front and center ── */
.ftr-card.is-active {
  opacity: 1;
  transform: translateX(0) scale(1) translateZ(0);
  box-shadow: 0 20px 60px rgba(0,0,0,0.14);
  z-index: 10;
  pointer-events: auto;
  cursor: default;
}

/* ── PREV: behind-left ── */
.ftr-card.is-prev {
  opacity: 0.45;
  transform: translateX(-52%) scale(0.78) translateZ(-120px) rotateY(8deg);
  z-index: 5;
  pointer-events: auto;
  cursor: pointer;
}

/* ── NEXT: behind-right ── */
.ftr-card.is-next {
  opacity: 0.45;
  transform: translateX(52%) scale(0.78) translateZ(-120px) rotateY(-8deg);
  z-index: 5;
  pointer-events: auto;
  cursor: pointer;
}

/* Further-back cards */
.ftr-card.is-prev2 {
  opacity: 0.18;
  transform: translateX(-80%) scale(0.62) translateZ(-220px) rotateY(14deg);
  z-index: 3;
  pointer-events: none;
}
.ftr-card.is-next2 {
  opacity: 0.18;
  transform: translateX(80%) scale(0.62) translateZ(-220px) rotateY(-14deg);
  z-index: 3;
  pointer-events: none;
}

/* Hover on side cards: slight pull forward */
.ftr-card.is-prev:hover {
  opacity: 0.65;
  transform: translateX(-48%) scale(0.82) translateZ(-80px) rotateY(6deg);
}
.ftr-card.is-next:hover {
  opacity: 0.65;
  transform: translateX(48%) scale(0.82) translateZ(-80px) rotateY(-6deg);
}

/* ── Card image (left half) ── */
.ftr-card-img {
  /* 1:1 ratio — square image on all views */
  flex: 0 0 auto;
  width: 300px;
  height: 300px;
  position: relative;
  overflow: hidden;
  background: var(--surface2);
  border-radius: 0;
}
.ftr-card-img img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 0.55s ease;
}
.ftr-card.is-active .ftr-card-img img { transform: scale(1.04); }

/* Image placeholder */
.ftr-img-ph {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--surface), var(--surface2));
  /* REPLACE: add background-image: url('fitur-X.jpg') here when ready */
}
.ftr-ph-icon { font-size: 2.8rem; opacity: 0.25; }
.ftr-ph-size {
  font-size: 10px; font-weight: 600;
  color: var(--ink4); letter-spacing: 0.5px;
  background: rgba(255,255,255,0.7);
  padding: 3px 9px; border-radius: 20px;
  border: 1px solid var(--border);
}

/* ── Card body (right half) ── */
.ftr-card-body {
  flex: 1;
  padding: 28px 28px;
  display: flex; flex-direction: column;
  justify-content: center;
  gap: 6px;
}

.ftr-num {
  font-size: 2.4rem; font-weight: 900;
  color: var(--orange); opacity: 0.15;
  line-height: 1; margin-bottom: 0;
  font-family: var(--font);
}
.ftr-label {
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--orange);
}
.ftr-name {
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  font-weight: 800; color: var(--ink);
  line-height: 1.2; margin-bottom: 6px;
}
.ftr-desc {
  font-size: 13px; color: var(--ink2);
  line-height: 1.7; flex: 1;
}
.ftr-badge {
  display: inline-block; font-size: 11px;
  font-weight: 700; color: #15803d;
  background: #f0fdf4; border: 1px solid #bbf7d0;
  padding: 3px 10px; border-radius: 20px;
  margin-top: 6px; align-self: flex-start;
}
.ftr-badge--bonus {
  color: var(--orange); background: var(--orange-light);
  border-color: var(--orange-mid);
}

/* ── Progress bar ── */
.ftr-progress-wrap {
  width: min(480px, 80%);
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  margin: 28px auto 0;
  overflow: hidden;
}
.ftr-progress-fill {
  height: 100%;
  background: var(--orange);
  border-radius: 2px;
  width: 0%;
  transition: width linear;
}

/* ── Dots ── */
.ftr-dots {
  display: flex; align-items: center;
  justify-content: center; gap: 8px;
  margin-top: 20px;
}
.ftr-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--border2); border: none; cursor: pointer; padding: 0;
  transition: background 0.25s, width 0.3s, border-radius 0.3s;
}
.ftr-dot.active {
  background: var(--orange);
  width: 24px; border-radius: 4px;
}

/* ── RESPONSIVE ── */
@media (max-width: 900px) {
  .ftr-track   { height: 300px; }
  .ftr-card    { width: min(600px, 90vw); height: 260px; }
  .ftr-card-body { padding: 20px 20px; flex: 1; }
  .ftr-num     { font-size: 2rem; }
  .ftr-name    { font-size: 1.15rem; }
  .ftr-card.is-prev { transform: translateX(-48%) scale(0.74) translateZ(-100px) rotateY(6deg); }
  .ftr-card.is-next { transform: translateX(48%) scale(0.74) translateZ(-100px) rotateY(-6deg); }
}

@media (max-width: 640px) {
  .ftr-stage  { perspective: 800px; padding: 28px 0 16px; }
  .ftr-track  { height: auto; min-height: 320px; padding-bottom: 12px; }

  /* Mobile: stack image top, text bottom */
  .ftr-card {
    flex-direction: column;
    width: 85vw; height: auto;
    min-height: 320px;
  }
  .ftr-card-img { flex: 0 0 140px; }
  .ftr-card-body { padding: 16px 18px; }

  .ftr-card.is-prev { transform: translateX(-55%) scale(0.72) translateZ(-80px); }
  .ftr-card.is-next { transform: translateX(55%) scale(0.72) translateZ(-80px); }
  .ftr-card.is-prev2,
  .ftr-card.is-next2 { opacity: 0; pointer-events: none; }
}


/* ════ REVISION CSS ════ */

/* ── 1. FITUR: Arrow buttons ── */
.ftr-arrow {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px; border-radius: 50%;
  background: #000; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  z-index: 20;
  box-shadow: 0 4px 20px rgba(0,0,0,0.25);
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
  opacity: 0;
  pointer-events: none;
}
.ftr-stage:hover .ftr-arrow,
.ftr-stage:focus-within .ftr-arrow { opacity: 1; pointer-events: auto; }
.ftr-arrow:hover { background: #222; transform: translateY(-50%) scale(1.08); box-shadow: 0 6px 28px rgba(0,0,0,0.35); }
.ftr-arrow:active { transform: translateY(-50%) scale(0.96); }
.ftr-arrow svg { width: 20px; height: 20px; pointer-events: none; }
.ftr-arrow-prev { left: clamp(8px, 2vw, 24px); }
.ftr-arrow-next { right: clamp(8px, 2vw, 24px); }
/* Always visible on touch devices */
@media (hover: none) {
  .ftr-arrow { opacity: 1; pointer-events: auto; }
}
/* Hide on very small mobile */
@media (max-width: 480px) { .ftr-arrow { display: none; } }

/* ── 2. BONUS SECTION ── */
.bonus-section { background: linear-gradient(180deg, #fff5f8 0%, var(--white) 100%); }
.bonus-cards-row {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px; margin-top: 0;
}
.bonus-card-new {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: 18px; padding: 28px 24px;
  position: relative; overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.bonus-card-new::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--orange); transform: scaleX(0); transform-origin: left;
  transition: transform 0.3s ease;
}
.bonus-card-new:hover { transform: translateY(-5px); box-shadow: var(--shadow3); border-color: var(--orange-mid); }
.bonus-card-new:hover::before { transform: scaleX(1); }
.bonus-card-new--featured {
  border-color: var(--orange-mid);
  background: linear-gradient(135deg, var(--orange-light) 0%, var(--white) 60%);
  box-shadow: 0 4px 24px rgba(255,45,122,0.1);
}
.bonus-card-new--featured::before { transform: scaleX(1); }
.bcn-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.bcn-icon { font-size: 2rem; }
.bcn-tag {
  font-size: 9px; font-weight: 800; letter-spacing: 1.5px;
  color: var(--ink3); background: var(--surface2);
  padding: 3px 10px; border-radius: 20px; text-transform: uppercase;
}
.bcn-tag--featured {
  color: var(--orange2); background: var(--orange-light);
  border: 1px solid var(--orange-mid);
}
.bcn-title { font-size: 1.1rem; font-weight: 800; color: var(--ink); margin-bottom: 8px; }
.bcn-desc { font-size: 13px; color: var(--ink2); line-height: 1.7; margin-bottom: 14px; }
.bcn-list { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.bcn-list li { font-size: 12.5px; color: var(--ink3); }
@media (max-width: 768px) { .bonus-cards-row { grid-template-columns: 1fr; gap: 14px; } }

/* ── 3. CLIENT LOGO: center ── */
.client-logo-grid { justify-items: center; place-items: center; }
.client-logo-more {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; text-align: center;
}

/* ── 4. PORTFOLIO ENDLESS LOOP ── */
.porto-loop-wrap {
  position: relative; overflow: hidden; margin-top: 12px;
}
.porto-loop-wrap::before, .porto-loop-wrap::after {
  content: ''; position: absolute; top: 0; bottom: 0;
  width: clamp(48px, 8vw, 100px); z-index: 2; pointer-events: none;
}
.porto-loop-wrap::before { left: 0; background: linear-gradient(to right, var(--white), transparent); }
.porto-loop-wrap::after  { right: 0; background: linear-gradient(to left, var(--white), transparent); }

.porto-loop-track {
  display: flex; gap: 16px; width: max-content;
  animation: portoEndless 28s linear infinite;
}
@keyframes portoEndless {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.porto-loop-card {
  position: relative; width: 280px; height: 420px;
  border-radius: 14px; overflow: hidden; flex-shrink: 0;
  background: var(--surface2); cursor: pointer;
}
.porto-loop-card img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 0.5s ease;
}
.porto-loop-card:hover img { transform: scale(1.06); }
.porto-loop-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.65) 0%, rgba(0,0,0,.1) 45%, rgba(0,0,0,0) 100%);
}
.porto-loop-title {
  position: absolute; top: 14px; left: 16px; right: 16px; z-index: 2;
  font-size: 13px; font-weight: 700; color: white;
  line-height: 1.3;
  text-shadow: 0 1px 6px rgba(0,0,0,0.5);
}

/* ── 5. TESTIMONI ENDLESS LOOP ── */
.testi-loop-wrap {
  position: relative; overflow: hidden; margin-top: 36px;
}
.testi-loop-wrap::before, .testi-loop-wrap::after {
  content: ''; position: absolute; top: 0; bottom: 0;
  width: clamp(48px, 8vw, 120px); z-index: 2; pointer-events: none;
}
.testi-loop-wrap::before { left: 0; background: linear-gradient(to right, var(--surface), transparent); }
.testi-loop-wrap::after  { right: 0; background: linear-gradient(to left, var(--surface), transparent); }

.testi-loop-track {
  display: flex; gap: 20px; width: max-content;
  animation: testiEndless 40s linear infinite;
}
/* No hover-pause = non-interruptible */
@keyframes testiEndless {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.testi-card-loop {
  width: 320px; flex-shrink: 0;
  background: var(--white); border: 1px solid var(--border);
  border-radius: 16px; padding: 22px 20px;
  display: flex; flex-direction: column; gap: 10px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
}
.tcl-quote {
  font-family: Georgia, serif; font-size: 2.6rem; font-weight: 900;
  color: var(--orange); line-height: .75; opacity: .25; user-select: none;
}
.tcl-text { font-size: 13px; color: var(--ink2); line-height: 1.72; flex: 1; }
.tcl-footer {
  display: flex; align-items: center; gap: 10px;
  padding-top: 12px; border-top: 1px solid var(--border); margin-top: auto;
}
.tcl-avatar {
  width: 34px; height: 34px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--orange), var(--orange2));
  color: white; font-size: 11px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}
.tcl-name  { font-size: 13px; font-weight: 700; color: var(--ink); }
.tcl-company { font-size: 11px; color: var(--ink3); margin-top: 1px; }

/* ── 6. BUTTON HOVER: premium split-fill ── */
.btn-primary, .btn-hero, .btn-form, .nav-cta, .pb-cta, .sticky-btn {
  position: relative; overflow: hidden;
  transition: color 0.35s cubic-bezier(0.22,1,0.36,1), box-shadow 0.35s ease, transform 0.2s ease;
}
.btn-primary::after, .btn-hero::after, .btn-form::after, .nav-cta::after {
  content: ''; position: absolute; inset: 0;
  background: rgba(0,0,0,0.15);
  transform: scaleX(0); transform-origin: left center;
  transition: transform 0.4s cubic-bezier(0.22,1,0.36,1);
  border-radius: inherit; z-index: 0;
}
.btn-primary > *, .btn-hero > *, .btn-form > *, .nav-cta > * { position: relative; z-index: 1; }
.btn-primary:hover::after, .btn-hero:hover::after,
.btn-form:hover::after, .nav-cta:hover::after { transform: scaleX(1); }
.btn-primary:hover, .btn-hero:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(255,45,122,0.4), 0 4px 12px rgba(255,45,122,0.2);
}
.btn-form:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(255,45,122,0.38);
}
.nav-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(255,45,122,0.32); }
.sticky-btn:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(255,45,122,0.4); }

/* ── 7. COUNTDOWN: CTA section ── */
.cta-countdown {
  display: flex; align-items: center; gap: 12px;
  justify-content: center; flex-wrap: wrap;
  margin: 16px 0;
}
.cta-cd-label {
  font-size: 12px; font-weight: 600; color: var(--ink3);
}
.cta-cd-blocks { display: flex; align-items: center; gap: 3px; }
.cta-cd-block {
  display: flex; flex-direction: column; align-items: center;
  background: var(--ink); border-radius: 6px; padding: 6px 10px; min-width: 44px;
}
.cta-cd-num { font-size: 18px; font-weight: 800; color: var(--orange); line-height: 1; }
.cta-cd-unit { font-size: 7px; color: rgba(255,255,255,0.45); margin-top: 2px; letter-spacing: 0.5px; }
.cta-cd-sep { font-size: 18px; font-weight: 700; color: var(--ink3); }

/* ── 7. COUNTDOWN: Sticky bar mini ── */
.sticky-cd-mini {
  display: flex; align-items: center; gap: 4px;
  font-size: 12px; font-weight: 600; color: var(--ink2);
  white-space: nowrap;
}
.sticky-cd-num { font-weight: 800; color: var(--orange2); font-size: 13px; }
.sticky-cd-sep { color: var(--ink4); font-size: 11px; }
.sticky-cd-txt { color: var(--ink3); font-size: 11px; }

/* Make sticky bar layout work with countdown */
.sticky-bar { display: none; flex-direction: column; gap: 8px; padding: 10px var(--px) 14px; box-sizing: border-box; width: 100%; }
@media (max-width: 680px) { .sticky-bar { display: flex; } }
.sticky-cd { display: flex; flex-direction: column; gap: 4px; width: 100%; }


/* ════ REVISION R2 CSS ════ */

/* ── 1. HERO CAROUSEL ── */
.hero-carousel { position: relative; border-radius: 18px; overflow: hidden; }
.hero-slides { display: flex; }
.hero-slide {
  flex: 0 0 100%; opacity: 0;
  position: absolute; top: 0; left: 0; width: 100%;
  transition: opacity 0.6s ease;
  pointer-events: none;
}
.hero-slide.active { opacity: 1; position: relative; pointer-events: auto; }
.hero-slide img { display: block; width: 100%; height: auto; aspect-ratio: 4/3; object-fit: cover; }
.hero-carousel-dots {
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 6px; z-index: 2;
}
.hero-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: rgba(255,255,255,0.5); border: none; cursor: pointer; padding: 0;
  transition: background 0.25s, width 0.25s;
}
.hero-dot.active { background: white; width: 20px; border-radius: 4px; }

/* ── 2. FITUR MOBILE: smooth 3D carousel ── */

/* Stage overflow: allow side cards to peek */
.ftr-stage { overflow: visible; padding: 28px 0 20px; }

/* Clip only vertically, allow horizontal peek */
.ftr-stage-clip {
  overflow: hidden;
  padding: 0 0 20px;
}

/* Mobile: show side cards partially */
@media (max-width: 640px) {
  .ftr-stage { perspective: 600px; padding: 24px 0 20px; margin-top: 0; }

  .ftr-card {
    width: min(82vw, 340px);
    flex-direction: column;
    height: auto;
    min-height: auto;
  }
  .ftr-card-img {
    flex: none;
    /* 1:1 ratio on mobile: full width, height = width */
    width: 100%;
    height: 0;
    padding-bottom: 100%;  /* creates 1:1 ratio */
    position: relative;
  }
  .ftr-card-img .ftr-img-ph,
  .ftr-card-img img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .ftr-img-ph { height: 100%; }
  .ftr-ph-icon { font-size: 2.2rem; }
  .ftr-card-body { padding: 20px 18px; flex: 1; gap: 14px; }
  .ftr-num { font-size: 1.8rem; margin-bottom: 0; line-height: 1; }
  .ftr-name { font-size: 1.05rem; }
  .ftr-desc { font-size: 12px; }

  /* Side cards: visible but faded, not clipped */
  .ftr-card.is-prev {
    transform: translateX(-48%) scale(0.8) translateZ(-60px);
    opacity: 0.55;
  }
  .ftr-card.is-next {
    transform: translateX(48%) scale(0.8) translateZ(-60px);
    opacity: 0.55;
  }
  .ftr-card.is-prev2 { transform: translateX(-76%) scale(0.65) translateZ(-110px); opacity: 0.2; }
  .ftr-card.is-next2 { transform: translateX(76%) scale(0.65) translateZ(-110px); opacity: 0.2; }
}

/* Dots: always visible, bigger on mobile */
.ftr-dots {
  display: flex !important;
  margin-top: 16px;
}
.ftr-dot {
  width: 9px; height: 9px; border-radius: 50%;
  transition: background 0.25s, width 0.3s, border-radius 0.3s;
}
.ftr-dot.active { background: var(--orange); width: 28px; border-radius: 4px; }

/* ── 3. STICKY BAR: standout countdown ── */
/* sticky-bar bg override moved to mobile query */
.sticky-cd-mini {
  background: rgba(255,45,122,0.12);
  border: 1px solid rgba(255,45,122,0.3);
  border-radius: 8px;
  padding: 6px 12px;
  display: flex; align-items: center; gap: 5px;
  justify-content: center;
}
.sticky-cd-txt { font-size: 10px; color: rgba(255,255,255,0.6); font-weight: 500; }
.sticky-cd-num {
  font-size: 15px; font-weight: 900;
  color: var(--orange); letter-spacing: 0.5px;
}
.sticky-cd-sep { color: rgba(255,45,122,0.5); font-weight: 700; font-size: 13px; }
.sticky-btn-DISABLED {
  background: var(--orange) !important;
  color: white !important;
  font-size: 14px !important; font-weight: 700 !important;
  padding: 13px !important; border-radius: 10px !important;
  letter-spacing: 0.3px;
}

/* ── 4. NAV COUNTDOWN: visible desktop, hidden mobile ── */
.nav-countdown { display: flex; }
@media (max-width: 768px) { .nav-countdown { display: none; } }

/* ── 5. CTA COUNTDOWN: simple inline ── */
.cta-cd-simple {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 10px; padding: 9px 18px;
  margin: 12px 0;
}
.cta-cd-simple-label {
  font-size: 12px; color: var(--ink3); font-weight: 500; white-space: nowrap;
}
.cta-cd-simple-nums {
  display: flex; align-items: center; gap: 4px;
}
.ccds-block {
  display: flex; flex-direction: column; align-items: center; gap: 1px;
}
.ccds-block b { font-size: 18px; font-weight: 800; color: var(--orange); line-height: 1; }
.ccds-block small { font-size: 9px; color: var(--ink3); text-transform: uppercase; letter-spacing: 0.5px; }
.ccds-sep { font-size: 16px; font-weight: 700; color: var(--ink4); padding-bottom: 10px; }

/* ── 6. CTA BONUS: simple horizontal list ── */
.cta-bonus-list {
  display: flex; flex-direction: column; gap: 10px;
  margin: 16px 0; text-align: left;
}
.cta-bonus-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
}
.cta-bonus-icon { font-size: 1.2rem; flex-shrink: 0; }
.cta-bonus-item div { display: flex; align-items: center; gap: 8px; flex: 1; }
.cta-bonus-item strong { font-size: 13px; color: var(--ink); }
.cta-bonus-tag {
  font-size: 9px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase;
  color: var(--orange2); background: var(--orange-light);
  border: 1px solid var(--orange-mid);
  padding: 2px 8px; border-radius: 20px; margin-left: auto; white-space: nowrap;
}

/* ── 7. PORTO LOOP: H3:W2 title only ── */
.porto-loop-card { border-radius: 16px; }
/* Already set width:280 height:420 */

/* ── 8. CLIENT LOGO: uniform rows ── */

.logo-more-row {
  display: flex; justify-content: center;
  margin-top: 20px;
  margin-bottom: 32px;
}
.logo-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: 12px; height: 72px; width: 100%;
  display: flex; align-items: center; justify-content: center;
  padding: 12px 16px; overflow: hidden;
  transition: border-color 0.25s, transform 0.25s, box-shadow 0.25s;
}
.logo-card:hover {
  border-color: var(--orange-mid);
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.07);
}
.logo-card img {
  max-height: 34px; width: auto; object-fit: contain;
  filter: grayscale(1) opacity(0.55);
  transition: filter 0.3s;
  display: block;
  margin: auto;
}
.logo-card:hover img { filter: grayscale(0) opacity(1); }
.logo-card--more {
  border-style: dashed; border-color: var(--orange-mid);
  background: var(--orange-light);
  width: 160px; flex-direction: column; gap: 8px;
  cursor: default;
}
.logo-card--more:hover { transform: none; box-shadow: none; }
.logo-card--more .clm-num { font-size: 1.4rem; font-weight: 900; color: var(--orange); line-height: 1; }
.logo-card--more .clm-label { font-size: 10px; font-weight: 700; color: var(--ink3); letter-spacing: 1px; text-transform: uppercase; }

@media (max-width: 900px) {
  
}
@media (max-width: 600px) {
  
  .logo-card {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px 10px;
  }
  .logo-card img {
    display: block;
    max-height: 26px;
    width: auto;
    margin: 0 auto;
  }
}
@media (max-width: 400px) {
  
  .logo-card {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .logo-card img {
    display: block;
    max-height: 22px;
    margin: 0 auto;
  }
}
/* ════ PREMIUM BUTTON HOVER ════ */
@keyframes btnShimmer {
  0%   { transform: translateX(-100%) skewX(-20deg); }
  100% { transform: translateX(220%) skewX(-20deg); }
}
.btn-hero, .btn-form, .nav-cta, .pb-cta, .sticky-btn {
  position: relative;
  overflow: hidden;
  transition:
    transform 0.25s cubic-bezier(0.22,1,0.36,1),
    box-shadow 0.25s cubic-bezier(0.22,1,0.36,1),
    background 0.2s ease;
  isolation: isolate;
}
/* Shimmer sweep on hover */
.btn-hero::before, .btn-form::before, .nav-cta::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 40%; height: 100%;
  background: rgba(255,255,255,0.22);
  transform: translateX(-100%) skewX(-20deg);
  transition: none;
  pointer-events: none;
  z-index: 1;
}
.btn-hero:hover::before, .btn-form:hover::before, .nav-cta:hover::before {
  animation: btnShimmer 0.55s cubic-bezier(0.22,1,0.36,1) forwards;
}
/* Lift + multi-layer shadow */
.btn-hero:hover {
  transform: translateY(-3px) scale(1.015);
  box-shadow:
    0 4px 0 rgba(0,0,0,0.18),
    0 8px 20px rgba(255,45,122,0.35),
    0 16px 40px rgba(255,45,122,0.2);
}
.btn-hero:active {
  transform: translateY(0) scale(0.98);
  box-shadow: 0 1px 4px rgba(255,45,122,0.3);
  transition-duration: 0.08s;
}
.btn-form:hover {
  transform: translateY(-2px);
  box-shadow:
    0 3px 0 rgba(0,0,0,0.15),
    0 6px 18px rgba(255,45,122,0.35),
    0 12px 32px rgba(255,45,122,0.18);
}
.btn-form:active {
  transform: translateY(0) scale(0.99);
  transition-duration: 0.08s;
}
.nav-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(255,45,122,0.4);
}
.sticky-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255,45,122,0.45);
  filter: brightness(1.06);
}

/* ════════════════════════════════════════
   UNIFIED CLIENT LOGO GRID
   Solusi final: auto-fill minmax
   - Desktop: 5 kolom
   - Tablet: 3-4 kolom
   - Mobile: 2 kolom
   - Ganjil → item terakhir otomatis center via justify-content:center
════════════════════════════════════════ */
.logo-unified-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 12px;
}

/* Logo card — uniform size, content always centered */
.logo-unified-grid .logo-card {
  width: 100%;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 16px;
}
.logo-unified-grid .logo-card img {
  display: block;
  max-height: 34px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  margin: auto;
  filter: grayscale(1) opacity(0.55);
  transition: filter 0.3s;
}
.logo-unified-grid .logo-card:hover img {
  filter: grayscale(0) opacity(1);
}

/* +50 row: always centered */
.logo-more-row {
  display: flex;
  justify-content: center;
  margin-top: 20px;
  margin-bottom: 32px;
}

/* ── Tablet: 5 → masih 5 tapi gap lebih kecil ── */
@media (max-width: 900px) {
  .logo-unified-grid {
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
  }
}

/* ── Mobile ≤600px: 2 kolom, ganjil center otomatis ── */
@media (max-width: 600px) {
  .logo-unified-grid {
    /* 2 kolom fixed — 10 item = 5 row rapi, tidak ada ganjil */
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    /* Jika jumlah berubah jadi ganjil: last item center */
    justify-items: stretch;
  }
  /* Jika item terakhir ganjil — paksa center */
  .logo-unified-grid .logo-card:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    max-width: 50%;
    margin: 0 auto;
  }
  .logo-unified-grid .logo-card {
    height: 64px;
    padding: 10px 12px;
  }
  .logo-unified-grid .logo-card img {
    max-height: 26px;
  }
}

@media (max-width: 400px) {
  .logo-unified-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .logo-unified-grid .logo-card {
    height: 56px;
    padding: 8px 10px;
  }
  .logo-unified-grid .logo-card img {
    max-height: 22px;
  }
}

/* ── CTA PRICE BLOCK ── */
.cta-price-block {
  margin: 20px 0 4px;
  padding: 20px 24px;
  background: linear-gradient(135deg, #fff0f5 0%, #fff8fc 100%);
  border: 2px solid var(--orange-mid);
  border-radius: 16px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
/* Subtle glow behind number */
.cta-price-block::before {
  content: '';
  position: absolute;
  width: 200px; height: 80px;
  background: radial-gradient(ellipse, rgba(255,45,122,0.12), transparent 70%);
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.cpb-label {
  font-size: 11px; font-weight: 700;
  color: var(--ink3); letter-spacing: 1.5px;
  text-transform: uppercase; margin-bottom: 8px;
}
.cpb-price {
  display: flex; align-items: baseline;
  justify-content: center; gap: 4px;
  margin-bottom: 8px; position: relative;
}
.cpb-currency {
  font-size: 1.2rem; font-weight: 800;
  color: var(--orange2); line-height: 1;
  align-self: flex-start; margin-top: 6px;
}
.cpb-amount {
  font-size: 2.8rem; font-weight: 900;
  color: var(--orange);
  line-height: 1; letter-spacing: -1px;
  font-family: var(--font);
  /* Text shadow untuk kedalaman */
  text-shadow:
    0 2px 0 rgba(255,45,122,0.2),
    0 4px 12px rgba(255,45,122,0.25);
}
.cpb-note {
  font-size: 11.5px; color: var(--ink3);
  line-height: 1.5;
}

/* ════════════════════════════════════════
   FITUR MOBILE FINAL FIX
   Konsolidasi semua override — block ini
   menang karena posisinya paling bawah di CSS
════════════════════════════════════════ */
@media (max-width: 640px) {

  /* Stage: beri ruang atas agar tidak nempel headline,
     ruang bawah agar tidak nempel section berikutnya */
  .ftr-stage {
    perspective: 600px;
    padding: 32px 0 48px;   /* top: space dari headline · bottom: space ke section bawah */
    margin-top: 8px;
    overflow: visible;       /* side cards tetap kelihatan */
  }

  /* Track: jangan fixed height — ikuti konten card */
  .ftr-track {
    height: auto !important;
    min-height: 480px;       /* cukup untuk card column + 1:1 image */
    padding-bottom: 0;
  }

  /* Card: column, auto height */
  .ftr-card {
    flex-direction: column !important;
    width: min(80vw, 320px) !important;
    height: auto !important;
    min-height: auto !important;
  }

  /* Image: 1:1 ratio via padding-bottom trick */
  .ftr-card-img {
    flex: none !important;
    width: 100% !important;
    height: 0 !important;
    padding-bottom: 100% !important;   /* 1:1 */
    position: relative !important;
  }
  .ftr-card-img .ftr-img-ph,
  .ftr-card-img img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  /* Card body */
  .ftr-card-body {
    padding: 20px 18px !important;
    gap: 12px !important;
    flex: 1 !important;
  }
  .ftr-num  { font-size: 1.6rem !important; margin-bottom: 0 !important; }
  .ftr-name { font-size: 1rem !important; }
  .ftr-desc { font-size: 12px !important; }

  /* Side cards: visible, di belakang */
  .ftr-card.is-prev {
    transform: translateX(-46%) scale(0.76) translateZ(-60px) !important;
    opacity: 0.5 !important;
  }
  .ftr-card.is-next {
    transform: translateX(46%) scale(0.76) translateZ(-60px) !important;
    opacity: 0.5 !important;
  }
  .ftr-card.is-prev2,
  .ftr-card.is-next2 {
    opacity: 0.15 !important;
    transform: translateX(-72%) scale(0.6) translateZ(-110px) !important;
  }
  .ftr-card.is-next2 {
    transform: translateX(72%) scale(0.6) translateZ(-110px) !important;
  }

  /* Dots tetap visible */
  .ftr-dots { margin-top: 20px; }
}

/* sticky-bar mobile handled in @media 768px block */


/* ════ STICKY BAR: definitive clean fix ════ */
/* Default hidden */
.sticky-bar { display: none !important; }

/* Mobile only */
@media (max-width: 768px) {
  .sticky-bar {
    display: flex !important;
    flex-direction: column;
    gap: 8px;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    width: 100%;
    box-sizing: border-box;
    padding: 10px 16px 14px;
    background: #1A0033;
    border-top: 2px solid var(--orange);
    z-index: 300;
  }
  .sticky-cd-mini {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 6px 10px;
    box-sizing: border-box;
    background: rgba(255,45,122,0.12);
    border: 1px solid rgba(255,45,122,0.3);
    border-radius: 8px;
  }
  .sticky-btn {
    display: block;
    width: 100%;
    box-sizing: border-box;
    text-align: center;
    padding: 13px 16px;
    font-size: 14px;
    font-weight: 700;
    background: var(--orange);
    color: white;
    border: none;
    border-radius: 10px;
    cursor: pointer;
  }
}


/* ═══════════════════════════════════════════
   XKALASI — BRAND GRADIENT OVERRIDES
   Gradient: #FF2D7A → #FF4D4D → #FF7A00
═══════════════════════════════════════════ */
.btn-hero,
.btn-form,
.sticky-btn {
  background: linear-gradient(135deg, #FF2D7A 0%, #FF4D4D 50%, #FF7A00 100%);
}
.nav-cta {
  background: linear-gradient(135deg, #FF2D7A, #FF7A00);
}
.promo-banner {
  background: linear-gradient(135deg, #FF2D7A, #FF7A00);
}
.guarantee-badge {
  background: linear-gradient(135deg, #FF2D7A, #FF7A00) !important;
}
.testi-avatar,
.tcl-avatar {
  background: linear-gradient(135deg, #FF2D7A, #FF7A00);
}
/* Nav wordmark-style xkalasi text (fallback if logo image missing) */
.nav-logo-text {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, #FF2D7A, #FF7A00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}



/* ═══════════════════════════════════════
   XKALASI — NAV LOGO SIZE
   Nav height: 68px. Logo image fits flush.
═══════════════════════════════════════ */
.nav-logo-img {
  display: block;
  height: 48px;
  width: auto;
  object-fit: contain;
  object-position: left center;
}
@media (max-width: 768px) {
  .nav-logo-img { height: 42px; }
}
@media (max-width: 480px) {
  .nav-logo-img { height: 38px; }
}

/* ════════════════════════════════════════
   TRUSTED BY SECTION
════════════════════════════════════════ */
.trusted-section {
  background: #0D001A;
  padding: clamp(40px,6vw,64px) var(--px);
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(255,45,122,0.12);
  border-bottom: 1px solid rgba(255,45,122,0.12);
}

/* Subtle gradient glow bg */
.trusted-section::before {
  content: '';
  position: absolute;
  width: 700px; height: 300px;
  border-radius: 50%;
  background: radial-gradient(ellipse, rgba(255,45,122,0.08), transparent 65%);
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

/* Header label */
.trusted-header {
  text-align: center;
  margin-bottom: 28px;
}
.trusted-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.35);
}

/* Stats row */
.trusted-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: 36px;
  flex-wrap: wrap;
}
.trusted-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 clamp(16px,4vw,40px);
  text-align: center;
}
.ts-num {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 800;
  line-height: 1;
  background: linear-gradient(135deg,#FF2D7A,#FF7A00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 4px;
}
.ts-plus {
  font-size: 0.65em;
  font-weight: 700;
}
.ts-label {
  font-size: 11px;
  color: rgba(255,255,255,0.4);
  font-weight: 500;
  letter-spacing: 0.5px;
}
.ts-divider {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,0.08);
  flex-shrink: 0;
}

/* Logo grid */
.trusted-logos {
  display: grid;
  grid-template-columns: repeat(4, 1fr) repeat(3, 1fr) 1fr;
  gap: 12px;
  align-items: stretch;
}

/* Base logo card */
.trusted-logo-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 14px;
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 90px;
  position: relative;
  overflow: hidden;
  transition: background 0.3s, border-color 0.3s, transform 0.3s;
}
.trusted-logo-card:hover {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,45,122,0.3);
  transform: translateY(-3px);
}

/* Featured card — 4 highlight client */
.trusted-logo-card.featured {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,45,122,0.18);
  min-height: 110px;
}
.trusted-logo-card.featured:hover {
  background: rgba(255,45,122,0.08);
  border-color: rgba(255,45,122,0.4);
  box-shadow: 0 8px 32px rgba(255,45,122,0.12);
}
/* Glow top border on featured */
.trusted-logo-card.featured::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg,#FF2D7A,#FF7A00);
  opacity: 0.7;
}

/* Badge (Enterprise, E-Commerce, etc.) */
.tl-badge {
  position: absolute;
  top: 10px; right: 10px;
  font-size: 8px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #FF2D7A;
  background: rgba(255,45,122,0.1);
  border: 1px solid rgba(255,45,122,0.2);
  padding: 2px 7px;
  border-radius: 20px;
}

/* Logo image */
.trusted-logo-card img {
  max-height: 36px;
  width: auto;
  max-width: 90%;
  object-fit: contain;
  filter: brightness(0) invert(1) opacity(0.55);
  transition: filter 0.3s;
}
.trusted-logo-card:hover img {
  filter: brightness(0) invert(1) opacity(0.9);
}

/* Fallback text when no image */
.tl-fallback {
  display: none;
  align-items: center;
  justify-content: center;
}
.tl-name {
  font-size: 15px;
  font-weight: 800;
  color: rgba(255,255,255,0.55);
  letter-spacing: -0.5px;
}
.tl-desc {
  font-size: 10px;
  color: rgba(255,255,255,0.3);
  text-align: center;
  line-height: 1.4;
}

/* +50 more card */
.more-card {
  border-style: dashed !important;
  border-color: rgba(255,45,122,0.25) !important;
  background: rgba(255,45,122,0.04) !important;
  cursor: default;
}
.more-card:hover {
  transform: none !important;
  box-shadow: none !important;
  background: rgba(255,45,122,0.07) !important;
}
.tl-more-num {
  font-size: 1.6rem;
  font-weight: 800;
  background: linear-gradient(135deg,#FF2D7A,#FF7A00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}
.tl-more-label {
  font-size: 10px;
  font-weight: 700;
  color: rgba(255,255,255,0.35);
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .trusted-logos {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (max-width: 600px) {
  .trusted-logos {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .trusted-logo-card.featured {
    min-height: 90px;
  }
  .trusted-stats { gap: 0; }
  .ts-divider { height: 24px; }
}
@media (max-width: 400px) {
  .trusted-stats { flex-wrap: wrap; gap: 16px; }
  .ts-divider { display: none; }
}

/* ════ TRUSTED BY — clean logo strip ════ */
.trusted-section {
  background: #0D001A;
  border-top: 1px solid rgba(255,45,122,0.1);
  border-bottom: 1px solid rgba(255,45,122,0.1);
  padding: 28px var(--px);
}
.trusted-inner {
  max-width: 1080px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 28px;
}
.trusted-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.25);
  white-space: nowrap;
  flex-shrink: 0;
}
.trusted-strip {
  display: flex;
  align-items: center;
  gap: 0;
  flex: 1;
  border-left: 1px solid rgba(255,255,255,0.07);
  padding-left: 28px;
}
.trusted-logo {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  border-right: 1px solid rgba(255,255,255,0.06);
}
.trusted-logo img {
  max-height: 28px;
  width: auto;
  max-width: 90%;
  object-fit: contain;
  /* White inverted — clean on dark bg */
  filter: brightness(0) invert(1) opacity(0.4);
  transition: filter 0.3s ease;
}
.trusted-logo:hover img {
  filter: brightness(0) invert(1) opacity(0.85);
}
/* +50 text slot */
.trusted-more {
  font-size: 13px;
  font-weight: 800;
  background: linear-gradient(135deg,#FF2D7A,#FF7A00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.5px;
  border-right: none;
}

@media (max-width: 900px) {
  .trusted-eyebrow { display: none; }
  .trusted-strip { border-left: none; padding-left: 0; }
  .trusted-inner { gap: 0; }
}
@media (max-width: 600px) {
  .trusted-section { padding: 20px var(--px); }
  .trusted-strip { flex-wrap: wrap; gap: 0; }
  .trusted-logo { flex: 0 0 33.33%; border-bottom: 1px solid rgba(255,255,255,0.06); }
}
