@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --paper:#f4ede1;
  --paper-2:#efe6d6;
  --ink:#221c16;
  --ink-soft:#5b5044;
  --line:#d8cbb4;
  --line-strong:#c4b393;
  --brass:#a8722e;
  --brass-deep:#8a5a1d;
  --green:#3f5a3a;
  --green-deep:#33492f;
}

#paymentModal .modal-content{
  background:var(--paper);
  border-radius:22px;
  border:1px solid var(--line-strong);
  overflow:hidden;
}

#paymentModal .modal-head{
  padding:26px 34px 20px;
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--paper-2),var(--paper));
}

#paymentModal .brandline{
  display:flex;
  align-items:center;
  gap:9px;
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--brass-deep);
  font-weight:600;
}

#paymentModal .dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--brass);
}

#paymentModal .stepper{
  display:flex;
  align-items:center;
  gap:14px;
  margin-top:18px;
}

#paymentModal .step-pill{
  display:flex;
  align-items:center;
  gap:10px;
}

#paymentModal .step-num{
  width:26px;
  height:26px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-size:12px;
  font-weight:700;
  border:1.5px solid var(--line-strong);
}

#paymentModal .step-pill.active .step-num{
  background:var(--brass);
  color:#fff;
}

#paymentModal .step-pill.done .step-num{
  background:var(--green);
  color:#fff;
}

#paymentModal .step-track{
  flex:1;
  height:2px;
  background:var(--line);
  position:relative;
}

#paymentModal .step-track::after{
  content:"";
  position:absolute;
  inset:0;
  width:var(--prog,0%);
  background:linear-gradient(90deg,var(--brass),var(--green));
  transition:.4s;
}

#paymentModal .modal-body{
  padding:28px 34px 34px;
}

#paymentModal .title{
  font-family:'Fraunces',serif;
  font-size:30px;
  margin-bottom:10px;
}

#paymentModal .title em{
  color:var(--brass-deep);
}

#paymentModal .subtitle{
  color:var(--ink-soft);
  margin-bottom:24px;
  font-size:14px;
}

#paymentModal .details{
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
}

#paymentModal .detail-row{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:14px;
  padding:15px 20px;
  border-bottom:1px solid var(--line);
}

#paymentModal .detail-row:last-child{
  border-bottom:none;
}

#paymentModal .detail-row dt{
  font-size:11px;
  text-transform:uppercase;
  color:var(--ink-soft);
}

#paymentModal .detail-row.amount dd{
  font-size:24px;
  font-family:'Fraunces',serif;
  color:var(--brass-deep);
}

#paymentModal .btn-primary-custom{
  background:var(--brass);
  border:none;
  color:#fff;
  padding:15px;
  border-radius:14px;
  width:100%;
  margin-top:25px;
  font-weight:600;
}

#paymentModal .btn-primary-custom:hover{
  background:var(--brass-deep);
}

#paymentModal .btn-success-custom{
  background:var(--green);
  border:none;
  color:#fff;
  padding:15px;
  border-radius:14px;
  width:100%;
  margin-top:25px;
  font-weight:600;
}

#paymentModal .btn-success-custom:hover{
  background:var(--green-deep);
}

#paymentModal .back-btn{
  border:none;
  background:none;
  margin-top:15px;
  color:var(--ink-soft);
}

#paymentModal #card-element{
  border:1px solid var(--line-strong);
  border-radius:14px;
  padding:18px;
  background:#fff;
}

@media(max-width:480px){

  #paymentModal .detail-row{
    grid-template-columns:1fr;
  }

  #paymentModal .title{
    font-size:24px;
  }
}