/* ============================================================
   GetSiap — Landing Page (premium, vanilla, tanpa build)
   ============================================================ */
:root{
  --bg:#f7f9fd; --surface:#ffffff; --ink:#0c1526; --muted:#5a667c;
  --line:#e4e9f2; --brand:#1857c4; --brand-2:#3b82f6; --brand-ink:#0f2b66;
  --brand-soft:#e7f0ff; --accent:#06b6d4; --ok:#1d9e75; --warn:#ba7517; --warn-soft:#fbeeda;
  --radius:14px; --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(12,21,38,.05),0 2px 8px rgba(12,21,38,.04);
  --shadow-md:0 2px 6px rgba(12,21,38,.06),0 12px 32px rgba(12,21,38,.08);
  --shadow-lg:0 4px 12px rgba(12,21,38,.08),0 24px 64px rgba(12,21,38,.12);
  --font:"Segoe UI Variable Display","Segoe UI",system-ui,-apple-system,Roboto,Arial,sans-serif;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0a101d; --surface:#111a2c; --ink:#e8edf6; --muted:#93a0b7;
    --line:#1e2a41; --brand:#4f8df1; --brand-2:#5f9bff; --brand-ink:#dce9ff;
    --brand-soft:#15243f; --warn-soft:#2b2214;
    --shadow-sm:0 1px 2px rgba(0,0,0,.4); --shadow-md:0 8px 28px rgba(0,0,0,.45);
    --shadow-lg:0 20px 60px rgba(0,0,0,.55);
  }
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--ink);
  line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:var(--brand);text-decoration:none}
img,svg{display:block;max-width:100%}
.container{max-width:1120px;margin:0 auto;padding:0 22px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--brand);color:#fff;
  padding:10px 16px;border-radius:0 0 10px 0;z-index:100}
.skip-link:focus{left:0}

/* ---------- Tombol ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;border-radius:12px;border:1px solid var(--line);
  background:var(--surface);color:var(--ink);font-size:15px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:transform .15s ease, box-shadow .15s ease,
  background .15s ease, border-color .15s ease}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:#c7d2e4}
.btn:active{transform:translateY(0)}
.btn-primary{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-2) 100%);
  border:none;color:#fff;box-shadow:0 4px 14px rgba(24,87,196,.35)}
.btn-primary:hover{box-shadow:0 6px 22px rgba(24,87,196,.45)}
.btn-lg{padding:15px 30px;font-size:16px;border-radius:14px}
.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn-ghost:hover{color:var(--ink);box-shadow:none;border-color:transparent;background:var(--brand-soft)}
:is(.btn,a,button,summary):focus-visible{outline:2px solid var(--brand);outline-offset:2px}

/* ---------- Navbar ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .25s ease, box-shadow .25s ease,
  border-color .25s ease;border-bottom:1px solid transparent}
.nav.scrolled{background:color-mix(in srgb, var(--surface) 82%, transparent);
  -webkit-backdrop-filter:saturate(1.6) blur(14px);backdrop-filter:saturate(1.6) blur(14px);
  border-color:var(--line);box-shadow:var(--shadow-sm)}
.nav .inner{max-width:1120px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:26px}
.nav .brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;color:var(--ink)}
.nav .logo{width:34px;height:34px;border-radius:10px;color:#fff;font-size:16px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--brand) 0%,var(--accent) 130%)}
.nav-links{display:flex;gap:4px;margin-left:8px}
.nav-links a{padding:8px 13px;border-radius:9px;color:var(--muted);font-size:14.5px;font-weight:500;
  transition:color .15s,background .15s}
.nav-links a:hover{color:var(--ink);background:var(--brand-soft)}
.nav-cta{margin-left:auto;display:flex;gap:10px;align-items:center}
.nav-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--line);
  border-radius:10px;padding:8px 10px;cursor:pointer;color:var(--ink)}

/* ---------- Hero ---------- */
.hero{position:relative;padding:150px 0 40px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(52% 44% at 78% 6%, color-mix(in srgb, var(--brand-2) 16%, transparent) 0%, transparent 100%),
    radial-gradient(40% 36% at 12% 22%, color-mix(in srgb, var(--accent) 12%, transparent) 0%, transparent 100%)}
.hero-grid-lines{position:absolute;inset:0;z-index:-1;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:56px 56px;
  -webkit-mask-image:radial-gradient(65% 60% at 50% 0%, #000 0%, transparent 100%);
  mask-image:radial-gradient(65% 60% at 50% 0%, #000 0%, transparent 100%)}
.hero .wrap{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;
  color:var(--brand);background:var(--brand-soft);border:1px solid color-mix(in srgb, var(--brand) 22%, transparent);
  padding:6px 14px;border-radius:100px;margin-bottom:22px}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--ok) 25%, transparent)}
.hero h1{font-size:clamp(34px,5.2vw,58px);line-height:1.08;letter-spacing:-.028em;
  font-weight:800;margin:0 0 20px}
.hero h1 .hl{background:linear-gradient(100deg,var(--brand) 10%,var(--accent) 90%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{font-size:clamp(16px,1.6vw,19px);color:var(--muted);max-width:520px;margin:0 0 30px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-note{font-size:13px;color:var(--muted);margin-top:14px}

/* Mockup CAT di hero (murni CSS) */
.mock{position:relative}
.mock-window{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);overflow:hidden;transform:perspective(1400px) rotateY(-6deg) rotateX(2deg);
  transition:transform .4s ease}
.mock:hover .mock-window{transform:perspective(1400px) rotateY(-2deg) rotateX(0)}
.mock-bar{display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--line)}
.mock-bar i{width:10px;height:10px;border-radius:50%;background:var(--line)}
.mock-bar i:nth-child(1){background:#f87171}.mock-bar i:nth-child(2){background:#fbbf24}.mock-bar i:nth-child(3){background:#34d399}
.mock-bar .url{margin-left:10px;font-size:11px;color:var(--muted);background:var(--bg);
  border-radius:6px;padding:3px 10px}
.mock-body{display:grid;grid-template-columns:1fr 92px;gap:12px;padding:16px}
.mock-q{border:1px solid var(--line);border-radius:12px;padding:14px}
.mock-tag{display:inline-block;font-size:10px;font-weight:700;color:var(--brand);
  background:var(--brand-soft);padding:3px 8px;border-radius:6px;margin-bottom:8px}
.mock-line{height:8px;border-radius:4px;background:var(--line);margin:7px 0}
.mock-line.w80{width:80%}.mock-line.w60{width:60%}
.mock-opt{display:flex;align-items:center;gap:8px;border:1px solid var(--line);
  border-radius:9px;padding:8px 10px;margin-top:8px;font-size:11px;font-weight:700;color:var(--muted)}
.mock-opt.sel{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}
.mock-opt .k{width:18px;height:18px;border-radius:5px;background:var(--bg);
  display:flex;align-items:center;justify-content:center;font-size:10px}
.mock-opt.sel .k{background:var(--brand);color:#fff}
.mock-side{display:flex;flex-direction:column;gap:8px}
.mock-timer{font-size:12px;font-weight:700;color:var(--brand);background:var(--brand-soft);
  border-radius:8px;padding:7px 0;text-align:center;font-variant-numeric:tabular-nums}
.mock-nav{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.mock-nav i{aspect-ratio:1;border-radius:5px;background:var(--bg);border:1px solid var(--line)}
.mock-nav i.d{background:var(--brand);border-color:var(--brand)}
.mock-nav i.r{background:var(--warn-soft);border-color:#eccf9a}
.chip-float{position:absolute;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow-md);padding:10px 14px;font-size:12.5px;font-weight:600;
  display:flex;align-items:center;gap:9px;animation:floaty 5s ease-in-out infinite}
.chip-float .ic{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.chip-float.c1{top:-16px;right:8px}
.chip-float.c2{bottom:-14px;left:-10px;animation-delay:1.6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ---------- Section umum ---------- */
section{padding:clamp(60px,8vw,104px) 0}
.sec-head{max-width:640px;margin:0 auto 52px;text-align:center}
.kicker{display:inline-block;font-size:13px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--brand);margin-bottom:12px}
.sec-head h2{font-size:clamp(26px,3.4vw,38px);line-height:1.15;letter-spacing:-.02em;margin:0 0 14px}
.sec-head p{color:var(--muted);margin:0;font-size:16.5px}

/* Reveal on scroll */
.rv{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .6s ease}
.rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.rv{opacity:1;transform:none}}

/* ---------- Statistik ---------- */
.stats{border-block:1px solid var(--line);background:var(--surface)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}
.stat{text-align:center;padding:26px 10px}
.stat .num{font-size:clamp(30px,3.6vw,44px);font-weight:800;letter-spacing:-.02em;
  font-variant-numeric:tabular-nums;
  background:linear-gradient(120deg,var(--brand),var(--accent));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lab{font-size:13.5px;color:var(--muted);font-weight:600;margin-top:4px}
.skel{position:relative;overflow:hidden;background:var(--line);border-radius:8px;color:transparent!important}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  animation:shimmer 1.4s infinite}
@media (prefers-color-scheme: dark){.skel::after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}}
@keyframes shimmer{100%{transform:translateX(100%)}}

/* ---------- Kartu grid (kategori & fitur) ---------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:26px;box-shadow:var(--shadow-sm);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  position:relative}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);
  border-color:color-mix(in srgb, var(--brand) 30%, var(--line))}
.card .ic{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--brand-soft);color:var(--brand);margin-bottom:16px}
.card h3{margin:0 0 8px;font-size:17px;letter-spacing:-.01em}
.card p{margin:0;color:var(--muted);font-size:14.5px}
.card .soon{position:absolute;top:16px;right:16px;font-size:11px;font-weight:700;
  color:var(--warn);background:var(--warn-soft);padding:3px 10px;border-radius:100px}
.card.is-soon{opacity:.72}
.card.is-soon:hover{transform:none;box-shadow:var(--shadow-sm)}

/* ---------- Demo preview ---------- */
.demo-wrap{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:28px;align-items:end}
.device{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);overflow:hidden}
.device .mock-body{grid-template-columns:1fr 110px}
.phone{width:min(240px,80%);margin:0 auto;border-radius:30px;border:1px solid var(--line);
  background:var(--surface);box-shadow:var(--shadow-md);overflow:hidden;padding:10px}
.phone .notch{width:80px;height:16px;border-radius:100px;background:var(--line);margin:2px auto 10px}
.phone .mock-q{border:none;padding:6px}
.phone .mock-opt{padding:7px 9px}

/* ---------- Cara kerja ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:step}
.step{position:relative;padding:24px;border-radius:var(--radius-lg);background:var(--surface);
  border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);
  font-size:13px;font-weight:800;color:var(--brand);letter-spacing:.06em}
.step h3{margin:10px 0 6px;font-size:16.5px}
.step p{margin:0;color:var(--muted);font-size:14px}

/* ---------- Testimoni ---------- */
.testi-scroll{display:grid;grid-auto-flow:column;grid-auto-columns:min(360px,84vw);gap:18px;
  overflow-x:auto;padding:6px 4px 18px;scroll-snap-type:x mandatory;scrollbar-width:thin}
.testi{scroll-snap-align:start}
.testi .stars{color:#f59e0b;letter-spacing:2px;font-size:14px;margin-bottom:10px}
.testi .who{display:flex;align-items:center;gap:12px;margin-top:16px}
.testi .av{width:40px;height:40px;border-radius:50%;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;font-weight:700}
.testi .who b{font-size:14.5px}
.testi .who span{display:block;font-size:12.5px;color:var(--muted)}

/* ---------- Pricing ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.plan{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-sm);position:relative;
  transition:transform .2s ease, box-shadow .2s ease}
.plan:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.plan.popular{border:2px solid var(--brand);box-shadow:var(--shadow-lg)}
.plan .pop-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-size:12px;
  font-weight:700;padding:4px 16px;border-radius:100px;white-space:nowrap}
.plan h3{margin:0 0 6px;font-size:19px}
.plan .desc{color:var(--muted);font-size:14px;margin:0 0 18px;min-height:42px}
.plan .price{display:flex;align-items:baseline;gap:8px;margin-bottom:20px}
.plan .price .cur{font-size:15px;font-weight:600;color:var(--muted)}
.plan .price .val{font-size:38px;font-weight:800;letter-spacing:-.02em}
.plan .price .strike{font-size:15px;color:var(--muted);text-decoration:line-through}
.plan ul{list-style:none;margin:0 0 26px;padding:0;flex:1}
.plan li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;padding:7px 0}
.plan li svg{flex:none;margin-top:3px;color:var(--ok)}
.plan .btn{width:100%}

/* ---------- FAQ ---------- */
.faq-list{max-width:760px;margin:0 auto}
.faq{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);
  margin-bottom:12px;overflow:hidden;transition:border-color .2s}
.faq[open]{border-color:color-mix(in srgb, var(--brand) 35%, var(--line));box-shadow:var(--shadow-sm)}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;gap:14px;
  align-items:center;padding:18px 22px;font-weight:600;font-size:15.5px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .chev{flex:none;transition:transform .25s ease;color:var(--muted)}
.faq[open] summary .chev{transform:rotate(180deg);color:var(--brand)}
.faq .ans{padding:0 22px 20px;color:var(--muted);font-size:14.5px}

/* ---------- CTA ---------- */
.cta-panel{position:relative;overflow:hidden;border-radius:calc(var(--radius-lg) + 6px);
  padding:clamp(44px,6vw,76px) clamp(24px,5vw,72px);text-align:center;color:#fff;
  background:linear-gradient(120deg,#0f2b66 0%,#1857c4 55%,#0e7490 120%)}
.cta-panel::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 90% at 80% 0%, rgba(255,255,255,.14), transparent)}
.cta-panel h2{font-size:clamp(26px,3.6vw,40px);letter-spacing:-.02em;margin:0 0 12px}
.cta-panel p{color:#cfe0ff;margin:0 auto 30px;max-width:460px;font-size:16.5px}
.cta-panel .btn{background:#fff;color:var(--brand-ink,#0f2b66);border:none;font-weight:700}
.cta-panel .btn:hover{box-shadow:0 8px 30px rgba(0,0,0,.3)}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--line);background:var(--surface);padding:56px 0 32px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:40px}
.foot-grid h4{font-size:13.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 14px}
.foot-grid a{display:block;color:var(--ink);font-size:14.5px;padding:5px 0;opacity:.85}
.foot-grid a:hover{color:var(--brand);opacity:1}
.foot-brand p{color:var(--muted);font-size:14px;max-width:280px;margin:12px 0 0}
.foot-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;
  gap:14px;flex-wrap:wrap;font-size:13.5px;color:var(--muted)}

/* ---------- Responsif ---------- */
@media(max-width:960px){
  .hero .wrap{grid-template-columns:1fr;gap:56px}
  .hero{padding-top:120px}
  .hero .lead{max-width:none}
  .mock-window{transform:none}
  .grid4{grid-template-columns:repeat(2,1fr)}
  .grid3{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .plan.popular{order:-1}
  .demo-wrap{grid-template-columns:1fr;justify-items:center}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .nav-links{position:fixed;inset:60px 14px auto;flex-direction:column;background:var(--surface);
    border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);padding:10px;
    display:none;z-index:70}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 16px;font-size:15px}
  .nav-toggle{display:block}
  .nav-cta .btn-ghost{display:none}
}
@media(max-width:560px){
  .grid3,.grid4,.steps{grid-template-columns:1fr}
  .hero-cta .btn{flex:1;min-width:150px}
  .chip-float{display:none}
  .foot-grid{grid-template-columns:1fr}
}
