/* =========================
   SDS DOCX PREMIUM MODAL
   ========================= */
.paywallModal{
  position:fixed;
  inset:0;
  z-index:4000;
  display:none;
}

.paywallModal.is-open{
  display:block;
}

.paywallBackdrop{
  position:absolute;
  inset:0;
  background:rgba(3,6,12,.74);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.paywallDialog{
  position:relative;
  z-index:1;
  width:min(720px, calc(100% - 24px));
  max-height:calc(100dvh - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
  margin:calc(env(safe-area-inset-top) + 12px) auto 12px;
  border-radius:22px;
  border:1px solid var(--gold-line);
  background:
    linear-gradient(180deg, rgba(20,26,40,.96), rgba(10,14,24,.985));
  box-shadow:
    0 24px 70px rgba(0,0,0,.42),
    inset 0 1px 0 rgba(255,255,255,.04),
    inset 0 0 0 1px rgba(214,177,94,.05);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

.paywallHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:18px 18px 12px;
  border-bottom:1px solid rgba(255,255,255,.06);
  flex:0 0 auto;
}

.paywallKicker{
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:6px;
}

.paywallTitle{
  margin:0;
  font-size:22px;
  color:var(--text);
  line-height:1.15;
}

.paywallClose{
  width:40px;
  min-width:40px;
  height:40px;
  padding:0;
  border-radius:12px;
  font-size:22px;
  line-height:1;
}

.paywallBody{
  padding:18px;
  overflow:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}

.paywallIntro p{
  margin:0 0 12px;
  color:var(--text-soft);
}

.paywallBenefits{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:14px;
}

.payBenefit{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  font-size:12px;
}

.paywallPriceBox{
  padding:12px 14px;
  border:1px solid var(--gold-line);
  border-radius:16px;
  background:rgba(214,177,94,.06);
  margin-bottom:14px;
}

.paywallPriceLabel{
  font-size:12px;
  color:var(--muted);
  margin-bottom:4px;
}

.paywallPriceValue{
  font-size:28px;
  font-weight:900;
  color:#fff2cf;
}

.paywallPlans{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:10px;
  margin-bottom:14px;
}

.payPlan{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(255,255,255,.02);
  cursor:pointer;
}

.payPlan input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.payPlan.active{
  border-color:var(--gold-line-2);
  background:rgba(214,177,94,.08);
  box-shadow:0 0 0 1px rgba(214,177,94,.08) inset;
}

.payPlanName{
  font-weight:800;
  color:var(--text);
}

.payPlanMeta{
  font-size:13px;
  color:var(--muted);
}

.paywallMethods{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:14px;
}

.payMethod{
  flex:1 1 0;
  min-width:160px;
}

.payMethod.active{
  border-color:var(--gold-line-2);
  background:linear-gradient(180deg, rgba(58,46,26,.98), rgba(33,26,16,.99));
  color:#fff5de;
}

.paywallPanel{
  display:none;
  padding:14px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.02);
}

.paywallPanel.active{
  display:block;
}

.paywallMiniTitle{
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:8px;
}

.paywallInstructions{
  margin-bottom:12px;
}

.paywallInfoGrid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:10px;
  margin-top:10px;
}

.paywallInfoGrid > div{
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:rgba(255,255,255,.02);
}

.labelLike{
  display:block;
  font-size:11px;
  color:var(--muted);
  margin-bottom:4px;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.paywallStatus{
  margin-top:14px;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:14px;
  color:var(--muted);
  background:rgba(255,255,255,.02);
  min-height:48px;
}

.paywallStatus.ok{color:var(--ok);}
.paywallStatus.bad{color:var(--bad);}
.paywallStatus.warn{color:var(--warn);}

/* Voucher-specific helpers */
.paywallVoucherRow{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:end;
}

.paywallVoucherHint{
  margin-top:8px;
  font-size:12px;
  color:var(--muted);
  line-height:1.5;
}

.paywallCode{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
  letter-spacing:.02em;
}

/* Responsive */
@media (max-width:700px){
  .paywallPlans{
    grid-template-columns:1fr;
  }

  .paywallInfoGrid{
    grid-template-columns:1fr;
  }

  .paywallVoucherRow{
    grid-template-columns:1fr;
  }

  .paywallDialog{
    width:min(720px, calc(100% - 12px));
    max-height:calc(100dvh - 12px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    margin:calc(env(safe-area-inset-top) + 6px) auto 6px;
    border-radius:18px;
  }

  .paywallBody,
  .paywallHead{
    padding:14px;
  }

  .paywallTitle{
    font-size:20px;
  }
}