.paket-head{ text-align:center; margin:34px auto 8px; max-width:640px; }
.paket-head h2{ font-size:26px; color:var(--ink); margin:0 0 8px; }
.paket-head p{ color:var(--muted); margin:0 0 16px; line-height:1.55; }
.saldo{ display:inline-block; background:#eef2ff; color:#1d4ed8; font-weight:600; padding:9px 16px; border-radius:999px; font-size:14px; }
.saldo b{ font-size:16px; }
.paket-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; max-width:880px; margin:26px auto 60px; }
.paket{ position:relative; background:#fff; border:1.5px solid var(--line); border-radius:18px; padding:28px 20px; text-align:center; transition:.15s; }
.paket:hover{ border-color:var(--blue); transform:translateY(-3px); box-shadow:0 12px 30px rgba(37,99,235,.12); }
.paket.pop{ border-color:var(--blue); box-shadow:0 12px 30px rgba(37,99,235,.14); }
.pk-badge{ position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--orange); color:#fff; font-size:12px; font-weight:700; padding:5px 14px; border-radius:999px; white-space:nowrap; }
.pk-top{ display:flex; align-items:baseline; justify-content:center; gap:6px; }
.pk-jml{ font-size:46px; font-weight:800; color:var(--ink); line-height:1; }
.pk-unit{ color:var(--muted); font-weight:600; }
.pk-harga{ font-size:22px; font-weight:800; color:var(--blue); margin:12px 0 4px; }
.pk-note{ color:var(--muted); font-size:13px; min-height:18px; margin-bottom:18px; }
.pk-beli{ width:100%; background:var(--blue); color:#fff; border:none; padding:12px; border-radius:11px; font-size:15px; font-weight:700; cursor:pointer; transition:.15s; }
.pk-beli:hover{ background:var(--blue-d); }
.modal{ display:none; position:fixed; inset:0; background:rgba(15,23,42,.5); align-items:center; justify-content:center; padding:20px; z-index:60; }
.modal.show{ display:flex; }
.m-card{ background:#fff; border-radius:18px; max-width:380px; width:100%; padding:26px 24px; text-align:center; box-shadow:0 24px 60px rgba(15,23,42,.25); }
.m-ic{ font-size:46px; }
.m-card h3{ margin:8px 0 6px; font-size:20px; color:var(--ink); }
.m-card p{ color:var(--muted); margin:0 0 20px; font-size:14.5px; line-height:1.55; }
.m-card .go{ width:100%; background:var(--blue); color:#fff; border:none; padding:12px; border-radius:11px; font-weight:700; font-size:15px; cursor:pointer; }
.m-card .go:hover{ background:var(--blue-d); }
.m-card .sec{ display:block; margin-top:12px; color:var(--muted); font-size:13.5px; text-decoration:none; cursor:pointer; }
@media(max-width:760px){ .paket-grid{ grid-template-columns:1fr; max-width:420px; } }
