/* timeline */
.timeline{position:relative;margin-top:48px}
.timeline::before{content:"";position:absolute;inset-block:24px 24px;inset-inline-start:31px;width:2px;background:var(--line-strong)}
.tstep{position:relative;display:grid;grid-template-columns:64px 1fr;gap:24px;padding-bottom:34px}
.tstep:last-child{padding-bottom:0}
.tstep .dot{width:64px;height:64px;border-radius:18px;background:var(--green-700);color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:1.5rem;
  box-shadow:0 8px 18px rgba(14,91,61,.22);z-index:1}
.tstep:nth-child(even) .dot{background:var(--gold);color:#3a2c0c;box-shadow:0 8px 18px rgba(198,151,73,.28)}
.tstep .body{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 28px;box-shadow:var(--shadow-sm)}
.tstep h3{font-size:1.3rem;margin-bottom:8px}
.tstep p{color:var(--ink-soft);font-weight:300;font-size:1.02rem}

/* logistics flow */
.flow{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch}
.flow .fc{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 24px;text-align:center;box-shadow:var(--shadow-sm)}
.flow .fc .ic{width:60px;height:60px;border-radius:16px;background:var(--green-tint);color:var(--green-700);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.flow .fc .ic svg{width:30px;height:30px;stroke:currentColor;fill:none;stroke-width:1.6}
.flow .fc h3{font-size:1.15rem;margin-bottom:8px}
.flow .fc p{color:var(--ink-soft);font-weight:300;font-size:.95rem}
.flow .arrow{display:none}

/* subscribe block */
.sub-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(32px,5vw,56px);align-items:center}
.sub-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden}
.sub-card .top{background:linear-gradient(135deg,var(--green-800),var(--green-700));color:#fff;padding:26px 30px;position:relative}
.sub-card .top .flagstrip{position:absolute;inset-inline:0;bottom:0}
.sub-card .top .amt{font-family:var(--font-display);font-weight:700;font-size:2.4rem;line-height:1}
.sub-card .top .amt small{font-size:1rem;font-weight:500;color:#bfd6c9}
.sub-card .top p{color:#cfe3d7;font-size:.95rem;margin-top:4px;font-weight:300}
.sub-card .form{padding:28px 30px}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.92rem;color:var(--ink-soft);font-weight:300}
.consent input{margin-top:4px}
.feat-list .ic svg{stroke:currentColor}
@media (max-width:880px){.flow{grid-template-columns:1fr}.sub-grid{grid-template-columns:1fr}}

.form-error{color:var(--red);font-size:.85rem;font-weight:500;margin-top:-2px}

/* ---- transfer / wallet card (subscribe section) ---- */
.pay-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);padding:22px}
.pay-head{display:flex;gap:13px;align-items:flex-start;margin-bottom:16px}
.pay-ic{width:44px;height:44px;border-radius:12px;background:var(--gold-tint);color:var(--gold-deep);
  display:flex;align-items:center;justify-content:center;flex:none}
.pay-ic svg{width:22px;height:22px}
.pay-title{font-family:var(--font-display);font-weight:700;color:var(--green-800);font-size:1.06rem}
.pay-sub{font-size:.88rem;color:var(--muted);font-weight:300;margin-top:2px}
.pay-number{display:flex;align-items:center;gap:10px;justify-content:space-between;
  background:var(--green-tint);border:1px dashed var(--green-600);border-radius:var(--r-sm);
  padding:12px 16px;flex-wrap:wrap}
.pay-number .num{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--green-800);
  letter-spacing:.04em;direction:ltr;unicode-bidi:plaintext}
.copy-btn{display:inline-flex;align-items:center;gap:7px;cursor:pointer;
  background:var(--green-700);color:#fff;border:0;border-radius:999px;padding:9px 16px;
  font-family:var(--font-body);font-weight:600;font-size:.9rem;transition:.18s}
.copy-btn:hover{background:var(--green-800)}
.copy-btn.copied{background:var(--gold-deep)}
.copy-btn svg{width:17px;height:17px}
.pay-holder{margin-top:12px;font-size:.92rem;color:var(--ink-soft)}
.pay-note{margin-top:6px;font-size:.88rem;color:var(--muted);font-weight:300}
.field-hint{font-size:.82rem;color:var(--muted);font-weight:300}

/* ---- payment card: body layout + QR + fallback ---- */
.pay-body{display:flex;gap:20px;align-items:flex-start}
.pay-main{flex:1;min-width:0}
.pay-label{font-size:.8rem;font-weight:600;color:var(--muted);margin-bottom:7px}
.pay-fallback{margin-top:16px;padding-top:16px;border-top:1px dashed var(--line-strong)}
.pay-fallback-txt{font-size:.9rem;color:var(--ink-soft);font-weight:300;margin-bottom:9px}
.pay-number--alt{background:var(--gold-tint);border-color:var(--gold-deep)}
.pay-number--alt .num{font-size:1.3rem;color:var(--gold-deep)}
.pay-qr{flex:none;width:142px;display:flex;flex-direction:column;align-items:center;gap:8px}
.pay-qr img{width:142px;height:142px;object-fit:contain;background:#fff;
  border:1px solid var(--line);border-radius:var(--r-sm);padding:8px;box-shadow:var(--shadow-sm)}
.pay-qr span{font-size:.8rem;color:var(--muted)}
@media (max-width:560px){
  .pay-body{flex-direction:column}
  .pay-qr{width:100%;align-self:center}
}
