.svc-body{background:var(--bg);min-height:100vh}
.svc-top{position:sticky;top:0;z-index:60;backdrop-filter:blur(20px);background:color-mix(in srgb,var(--bg) 82%,transparent)}
.svc-top-in{max-width:480px;margin:0 auto;display:flex;align-items:center;gap:13px;height:60px;padding:0 16px}
.svc-top-in h1{font-size:17px;font-weight:600;letter-spacing:-.2px}

/* premium back fab */
.back-fab{width:40px;height:40px;border-radius:13px;border:1px solid var(--line);background:var(--surface);
  color:var(--on-bg);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;
  transition:.2s;box-shadow:0 2px 8px rgba(16,24,40,.05);flex-shrink:0}
.back-fab:active{transform:scale(.9)}
.back-fab:hover{border-color:color-mix(in srgb,var(--primary) 30%,transparent);color:var(--primary)}

.svc-flow{max-width:480px;margin:0 auto;padding:6px 22px 36px;min-height:calc(100vh - 60px);display:flex;flex-direction:column}
.flow-illus{display:flex;justify-content:center;margin:0}
.flow-illus dotlottie-wc{width:150px;height:150px}

.flow-bar{display:flex;gap:6px;margin-bottom:28px}
.flow-bar .fb{flex:1;height:4px;border-radius:99px;background:var(--line);transition:.35s}
.flow-bar .fb.on{background:linear-gradient(90deg,var(--primary),var(--primary-2))}

.flow-step{animation:flowIn .4s cubic-bezier(.22,1,.36,1);flex:1;display:flex;flex-direction:column}
@keyframes flowIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
.flow-step h2{font-size:18px;font-weight:600;letter-spacing:-.3px;margin-bottom:5px;color:var(--on-bg)}
.flow-hint{color:var(--on-muted);font-size:13.5px;margin-bottom:24px}

/* network picker */
.net-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
.netp{display:flex;flex-direction:column;align-items:center;gap:9px;padding:16px 8px;border-radius:18px;
  border:1.5px solid var(--line);background:transparent;cursor:pointer;transition:.2s}
.netp img{width:38px;height:38px;border-radius:11px;object-fit:cover}
.netp span{font-size:12.5px;font-weight:600;color:var(--on-bg)}
.netp:active{transform:scale(.95)}
.netp.on{border-color:var(--primary);background:var(--primary-soft)}

/* phone input */
.flow-input-wrap{position:relative;display:flex;align-items:center;margin-bottom:auto}
.flow-input-wrap input{width:100%;padding:14px 4px;border:none;border-bottom:1.5px solid var(--line);
  background:transparent;color:var(--on-bg);font-size:18px;font-weight:600;font-family:inherit;outline:none;transition:.2s;letter-spacing:.5px}
.flow-input-wrap input:focus{border-bottom-color:var(--primary)}
.flow-input-wrap input::placeholder{color:var(--on-muted);opacity:.4;font-weight:500}
.svc-self{position:absolute;right:0;padding:8px 16px;border-radius:999px;border:none;background:var(--primary-soft);color:var(--primary);font-weight:700;font-size:12.5px;cursor:pointer}
.svc-self:active{transform:scale(.94)}

/* amount */
.flow-amount{display:flex;align-items:baseline;justify-content:center;gap:8px;padding:12px 0 22px}
.flow-cur{font-size:17px;font-weight:600;color:var(--on-muted)}
.flow-amount input{width:auto;max-width:170px;border:none;background:transparent;color:var(--on-bg);
  font-size:38px;font-weight:700;letter-spacing:-1.5px;font-family:inherit;outline:none;text-align:center}
.flow-amount input::placeholder{color:var(--line)}
.flow-amount input::-webkit-outer-spin-button,.flow-amount input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.amt-chips{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.amt-chips button{padding:12px 0;border-radius:13px;border:1.5px solid var(--line);background:transparent;
  color:var(--on-bg);font-weight:600;font-size:14px;cursor:pointer;transition:.2s}
.amt-chips button:active{transform:scale(.95)}
.amt-chips button.on{background:var(--primary);border-color:var(--primary);color:#fff}

/* confirm list */
.confirm-list{margin-bottom:auto}
.cfm-row{display:flex;align-items:center;justify-content:space-between;padding:15px 2px;border-bottom:1px solid var(--line)}
.cfm-row span{color:var(--on-muted);font-size:13.5px}
.cfm-row strong{font-size:14.5px;font-weight:600;color:var(--on-bg)}
.cfm-row.total{border-bottom:none;padding-top:20px}
.cfm-row.total span{font-weight:600;color:var(--on-bg);font-size:14.5px}
.cfm-row.total strong{font-size:18px;font-weight:700;color:var(--primary)}

.flow-next{width:100%;padding:16px;border-radius:999px;border:none;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:700;font-size:15.5px;cursor:pointer;transition:.2s;box-shadow:0 10px 26px color-mix(in srgb,var(--primary) 30%,transparent);margin-top:26px}
.flow-next:active{transform:scale(.98)}
.flow-next:disabled{opacity:.6;cursor:wait}

.bspin{display:inline-block;width:16px;height:16px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:bspin .7s linear infinite;vertical-align:middle;margin-right:6px}
@keyframes bspin{to{transform:rotate(360deg)}}

/* SIM owner name - premium fintech */
.sim-name{margin:14px 0 0;min-height:24px;transition:.25s}
.sim-name:empty{margin:0;min-height:0}
.sim-name.loading{display:inline-flex;align-items:center;gap:9px;padding:9px 16px;border-radius:999px;
  background:var(--surface-2);border:1px solid var(--line);color:var(--on-muted);font-size:13px;font-weight:500}
.sim-name.loading .dotpulse{display:inline-flex;gap:3px}
.sim-name.loading .dotpulse span{width:5px;height:5px;border-radius:50%;background:var(--primary);animation:dotp 1.2s ease-in-out infinite}
.sim-name.loading .dotpulse span:nth-child(2){animation-delay:.2s}
.sim-name.loading .dotpulse span:nth-child(3){animation-delay:.4s}
@keyframes dotp{0%,60%,100%{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}
.sim-name.ok{display:inline-flex;align-items:center;gap:10px;padding:10px 16px 10px 12px;border-radius:999px;
  background:color-mix(in srgb,var(--primary) 10%,transparent);border:1px solid color-mix(in srgb,var(--primary) 22%,transparent);
  color:var(--on-bg);font-size:13.5px;font-weight:600;animation:simIn .3s cubic-bezier(.22,1,.36,1)}
.sim-name.ok .vbadge{width:20px;height:20px;border-radius:50%;background:#2f6bff;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}
@keyframes simIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.sim-name.err{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;
  background:color-mix(in srgb,#e5484d 10%,transparent);border:1px solid color-mix(in srgb,#e5484d 22%,transparent);
  color:#e5484d;font-size:13px;font-weight:500}

/* compact step: button directly under field */
.flow-step.compact{flex:initial}
.flow-step.compact .flow-input-wrap{margin-bottom:0}
.flow-step.compact .flow-next{margin-top:24px}
.w-label{display:block;font-size:13px;font-weight:600;color:var(--on-muted);margin-bottom:8px}
.oos{font-size:11px;font-weight:600;color:#e5484d;background:color-mix(in srgb,#e5484d 12%,transparent);padding:2px 8px;border-radius:999px;margin-left:6px}
.bundle-item[disabled]{opacity:.55;cursor:not-allowed}
.txn-loading{display:flex;justify-content:center;padding:30px}
.txn-loading i{font-size:28px;color:var(--primary)}
.mono{font-family:ui-monospace,monospace}
.res-ic{width:72px;height:72px;border-radius:50%;margin:10px auto 18px;display:flex;align-items:center;justify-content:center;font-size:30px}
.res-ic.ok{background:#e8f7f0;color:#00a76f}
.plat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.plat-grid .txn-loading{grid-column:1/-1;justify-content:center}
.plat-tile{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 8px;border-radius:18px;border:1.5px solid var(--line);background:transparent;cursor:pointer;transition:.2s}
.plat-tile:active{transform:scale(.95)}
.plat-tile img{width:40px;height:40px;border-radius:11px;object-fit:contain}
.plat-tile .plat-fb{width:40px;height:40px;border-radius:11px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}
.plat-tile span:last-child{font-size:12px;font-weight:600;color:var(--on-bg);text-align:center}
.quote-box{display:flex;align-items:center;justify-content:space-between;margin-top:22px;padding:16px 18px;border-radius:16px;background:var(--primary-soft);border:1px solid color-mix(in srgb,var(--primary) 22%,transparent)}
.quote-box span{font-size:14px;color:var(--on-bg);font-weight:500}
.quote-box strong{font-size:19px;font-weight:700;color:var(--primary)}
.dep-secure{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:20px;color:var(--on-muted);font-size:12.5px;font-weight:500}
.dep-shield{width:22px;height:22px;border-radius:50%;background:color-mix(in srgb,#00a76f 14%,transparent);color:#00a76f;display:flex;align-items:center;justify-content:center;font-size:11px}
.dep-min{text-align:center;font-size:12.5px;color:var(--on-muted);margin-top:16px}
.dep-note{text-align:center;font-size:13px;color:var(--on-muted);margin-top:14px}
.dep-note span{color:var(--primary);font-weight:700}
