/* ─── ORDER MAIN ─── */

.order-main{
  padding:140px 0 100px;
  background:var(--cream);
  min-height:100vh;
}

.order-breadcrumb{
  margin-bottom:40px;
}

.breadcrumb{
  display:flex;
  align-items:center;
  gap:10px;
}

.breadcrumb a{
  color:var(--muted);
  text-decoration:none;
  font-size:13px;
  transition:.2s;
}

.breadcrumb a:hover{
  color:var(--gold);
}

.breadcrumb span{
  color:var(--muted);
  font-size:13px;
}

.breadcrumb span:last-child{
  color:var(--primary);
  font-weight:500;
}

/* ─── GRID ─── */

.order-grid{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:32px;
  align-items:start;
}

/* ─── FORM BLOCKS ─── */

.order-forms{
  display:flex;
  flex-direction:column;
  gap:24px;
}

.form-block{
  background:#fff;
  border:1px solid var(--border);
  border-radius:4px;
  padding:40px 44px;
}

.form-block-header{
  display:flex;
  align-items:flex-start;
  gap:20px;
  margin-bottom:36px;
  padding-bottom:28px;
  border-bottom:1px solid var(--border);
}

.step-num{
  font-family:'Cormorant Garamond',serif;
  font-size:48px;
  color:var(--cream-dark);
  line-height:1;
  font-weight:700;
  flex-shrink:0;
  margin-top:-6px;
}

.form-block-header h2{
  font-size:30px;
  color:var(--primary);
  margin-bottom:4px;
  line-height:1.1;
}

.form-block-header p{
  font-size:13.5px;
}

/* ─── FORM ROWS ─── */

.form-row{
  margin-bottom:20px;
}

.form-row:last-child{
  margin-bottom:0;
}

.two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.three-col{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:16px;
}

/* ─── FORM ELEMENTS ─── */

.form-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.form-group label{
  font-size:12px;
  font-weight:600;
  color:var(--primary);
  letter-spacing:.5px;
  text-transform:uppercase;
  font-family:'Inter',sans-serif;
}

.optional{
  font-size:10px;
  color:var(--muted);
  font-weight:400;
  text-transform:none;
  letter-spacing:0;
}

.form-group input,
.form-group select,
.form-group textarea{
  border:1px solid var(--border);
  border-radius:4px;
  padding:13px 16px;
  font-size:14.5px;
  font-family:'Inter',sans-serif;
  color:var(--text);
  background:#fff;
  outline:none;
  transition:border-color .2s, box-shadow .2s;
  width:100%;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(28,43,22,.06);
}

.form-group input.input-error{
  border-color:#c0392b;
  box-shadow:0 0 0 3px rgba(192,57,43,.08);
}

.form-group textarea{
  resize:vertical;
  min-height:90px;
}

/* ─── QTY INPUT ─── */

.qty-input{
  display:flex;
  align-items:center;
  border:1px solid var(--border);
  border-radius:4px;
  overflow:hidden;
}

.qty-btn{
  background:var(--cream);
  border:none;
  width:44px;
  height:48px;
  font-size:18px;
  cursor:pointer;
  color:var(--primary);
  font-family:'Inter',sans-serif;
  transition:.2s;
  flex-shrink:0;
}

.qty-btn:hover{
  background:var(--primary);
  color:white;
}

.qty-input input{
  border:none !important;
  text-align:center;
  font-size:15px;
  font-weight:600;
  flex:1;
  min-width:0;
  box-shadow:none !important;
  border-radius:0 !important;
}

/* ─── PAYMENT METHODS ─── */

.payment-methods{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:28px;
}

.payment-method{
  border:1px solid var(--border);
  border-radius:4px;
  padding:16px 20px;
  display:flex;
  align-items:center;
  gap:12px;
  cursor:pointer;
  transition:.2s;
  font-size:14px;
  font-family:'Inter',sans-serif;
  color:var(--muted);
}

.payment-method input[type="radio"]{
  display:none;
}

.payment-method:hover{
  border-color:var(--primary);
  color:var(--primary);
}

.payment-method.active{
  border-color:var(--primary);
  background:var(--primary);
  color:white;
}

.pm-icon{
  font-size:18px;
}

/* ─── CARD PREVIEW ─── */

.card-preview{
  margin-bottom:28px;
}

.card-front{
  background:linear-gradient(135deg, #1C2B16, #3D5A2A);
  border-radius:12px;
  padding:28px 30px;
  color:white;
  position:relative;
  min-height:160px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  box-shadow:0 12px 40px rgba(28,43,22,.3);
}

.card-chip{
  width:36px;
  height:28px;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 100%);
  border-radius:4px;
  margin-bottom:20px;
}

.card-number-preview{
  font-family:'Courier New',monospace;
  font-size:18px;
  letter-spacing:3px;
  margin-bottom:16px;
}

.card-info-row{
  display:flex;
  gap:40px;
}

.card-info-row span{
  font-size:8px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.55);
  display:block;
  margin-bottom:4px;
}

.card-info-row p{
  font-size:13px;
  color:white;
  font-weight:500;
  font-family:'Inter',sans-serif;
}

/* ─── CVV ─── */

.cvv-wrap{
  position:relative;
}

.cvv-wrap input{
  padding-right:44px;
}

.cvv-info{
  position:absolute;
  right:14px;
  top:50%;
  transform:translateY(-50%);
  width:20px;
  height:20px;
  background:var(--border);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  color:var(--muted);
  cursor:help;
}

/* ─── SSL BADGE ─── */

.ssl-badge{
  display:flex;
  align-items:flex-start;
  gap:12px;
  background:var(--cream);
  border-radius:4px;
  padding:16px 18px;
  margin-top:20px;
  border:1px solid var(--border);
}

.ssl-badge span{
  font-size:16px;
  flex-shrink:0;
  margin-top:1px;
}

.ssl-badge p{
  font-size:12.5px;
  line-height:1.6;
}

/* ─── BANK INFO ─── */

.bank-info{
  border:1px solid var(--border);
  border-radius:4px;
  overflow:hidden;
}

.bank-row{
  display:flex;
  align-items:center;
  gap:20px;
  padding:14px 20px;
  border-bottom:1px solid var(--border);
}

.bank-row:last-child{
  border-bottom:none;
}

.bank-row span{
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500;
  width:100px;
  flex-shrink:0;
}

.bank-row p{
  font-size:14px;
  color:var(--text);
  font-weight:500;
}

/* ─── SUBMIT BTN ─── */

.submit-btn{
  background:var(--primary);
  color:white;
  border:none;
  padding:18px 40px;
  border-radius:4px;
  font-size:15px;
  font-family:'Inter',sans-serif;
  font-weight:600;
  cursor:pointer;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  letter-spacing:.5px;
  transition:.25s;
  margin-top:8px;
}

.submit-btn:hover{
  background:var(--secondary);
}

.submit-btn.loading{
  opacity:.7;
  cursor:not-allowed;
  pointer-events:none;
}

.btn-arrow{
  font-size:18px;
  transition:transform .2s;
}

.submit-btn:hover .btn-arrow{
  transform:translateX(4px);
}

/* ─── ORDER SUMMARY ─── */

.order-summary-col{
  position:sticky;
  top:120px;
}

.order-summary{
  background:#fff;
  border:1px solid var(--border);
  border-radius:4px;
  overflow:hidden;
}

.summary-header{
  padding:24px 28px;
  border-bottom:1px solid var(--border);
  background:var(--primary);
}

.summary-header h3{
  color:white;
  font-size:22px;
}

.summary-product{
  display:flex;
  align-items:center;
  gap:16px;
  padding:24px 28px;
  border-bottom:1px solid var(--border);
}

.summary-product-icon{
  width:48px;
  height:48px;
  background:var(--cream);
  border-radius:4px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  flex-shrink:0;
}

.summary-product-name{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;
  color:var(--primary);
  font-weight:600;
  line-height:1.2;
}

.summary-product-unit{
  font-size:12px;
  color:var(--muted);
  margin-top:3px;
}

.summary-rows{
  padding:20px 28px;
  border-bottom:1px solid var(--border);
}

.summary-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 0;
  font-size:14px;
}

.summary-row span:first-child{
  color:var(--muted);
}

.summary-row span:last-child{
  color:var(--text);
  font-weight:500;
}

.summary-divider{
  height:1px;
  background:var(--border);
}

.summary-total{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:24px 28px;
  border-bottom:1px solid var(--border);
}

.summary-total span:first-child{
  font-size:13px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--primary);
}

.summary-total span:last-child{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;
  color:var(--primary);
  font-weight:700;
}

.summary-note{
  padding:16px 28px;
  border-bottom:1px solid var(--border);
}

.summary-note p{
  font-size:12.5px;
  line-height:1.65;
}

.summary-note a{
  color:var(--gold);
  text-decoration:none;
}

.summary-note a:hover{
  color:var(--primary);
}

.summary-trust{
  display:flex;
  justify-content:space-around;
  padding:20px 28px;
}

.trust-item-sm{
  text-align:center;
}

.trust-item-sm span{
  font-size:16px;
  display:block;
  margin-bottom:4px;
}

.trust-item-sm p{
  font-size:10.5px;
  letter-spacing:1px;
  text-transform:uppercase;
  font-weight:500;
  color:var(--muted);
}

/* ─── SUCCESS SCREEN ─── */

.success-screen{
  position:fixed;
  inset:0;
  background:#fff;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .4s ease;
}

.success-screen.active{
  opacity:1;
  pointer-events:all;
}

.success-inner{
  text-align:center;
  max-width:480px;
  padding:40px;
}

.success-icon{
  width:80px;
  height:80px;
  background:var(--primary);
  color:white;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:32px;
  margin:0 auto 28px;
}

.success-inner h2{
  font-size:52px;
  color:var(--primary);
  margin-bottom:16px;
}

.success-inner p{
  font-size:15.5px;
  line-height:1.8;
  margin-bottom:24px;
}

.success-ref{
  background:var(--cream);
  border:1px solid var(--border);
  border-radius:4px;
  padding:14px 24px;
  font-size:14px;
  color:var(--primary);
  margin-bottom:32px;
  letter-spacing:1px;
}

.success-actions{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}

/* ─── RESPONSIVE ─── */

@media(max-width:992px){

  .order-grid{
    grid-template-columns:1fr;
  }

  .order-summary-col{
    position:static;
    order:-1;
  }

}

@media(max-width:640px){

  .form-block{
    padding:28px 24px;
  }

  .two-col,
  .three-col{
    grid-template-columns:1fr;
  }

  .payment-methods{
    grid-template-columns:1fr;
  }

}