:root{
  --brand:#b54b20; --brand-dark:#8f3817;
  --ink:#212529; --muted:#f4f5f7; --panel:#ffffff;
  --border:#e5e7eb; --focus:#2a64ff;
  --shadow:0 6px 18px rgba(0,0,0,.05);
  --radius:12px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:#fafafa;font-size:15px}

/* ===== Layout: 2/3 main + 1/3 aside ===== */
.fcd-wrap{max-width:1100px;margin:22px auto;padding:0 14px}
.fcd-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}
@media (max-width: 1024px){ .fcd-grid{grid-template-columns:1fr} }

/* ===== Steps (tabs) ===== */
.steps-indicator{grid-column:1/-1;list-style:none;display:flex;gap:10px;padding:0;margin:8px 0 14px}
.steps-indicator li{
  flex:1;text-align:center;height:46px;display:flex;align-items:center;justify-content:center;
  background:#fff;border:1px solid var(--border);border-radius:9px;font-weight:700;color:#6b7280;
  box-shadow:var(--shadow); font-size: 16px;
}
.steps-indicator li.active{border-color:var(--brand);background:#fff3ec;color:#111}

/* ===== Summary ===== */
.summary{
  background:var(--panel);
	border:1px solid var(--brand);
	border-radius:10px;
	padding:12px 14px;
  font-size:20px;
  font-weight: 500;
	box-shadow:var(--shadow);margin-bottom:16px;
  position: sticky;
  top: 160px;
	z-index:50;
}

/* ===== Main form card ===== */
.step{display:none;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow)}
.step.active{display:block}
.fcd-wrap h2{margin:0 0 14px;font-size:26px;line-height:1.25;font-size: 20px;}
.fcd-wrap h3{margin:18px 0 8px}
/*.fcd-wrap label{display:block;margin:10px 0 6px;font-weight:700;font-size:14px} */
.help{color:#6b7280;font-size:13px;margin:8px 0}

.fcd-wrap input,select,textarea{
  width:100%;padding:11px 12px;border:1px solid var(--border);border-radius:9px;
  font-size:15px;background:#fff;box-shadow:var(--shadow)
}
.fcd-wrap input:focus,select:focus,textarea:focus{outline:none;border-color:var(--focus);box-shadow:0 0 0 3px rgba(42,100,255,.15)}

.fcdgrid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px; width: 100%;margin-bottom: 0px;}
.fcdgrid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px; padding-bottom:0px;}
@media (max-width:680px){ .fcdgrid-2,.fcdgrid-3{grid-template-columns:1fr} }

/* ===== Amount grid ===== */
.amount-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:620px){ .amount-grid{grid-template-columns:repeat(2,1fr)} }

.amount-card{
  position:relative;display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--muted);border:2px solid transparent;border-radius:12px;height:65px;
  cursor:pointer;font-weight:600;font-size:20px;color:#0f172a;box-shadow:var(--shadow)
}
/* keep radio accessible but not visible */
.amount-card>input[type="radio"]{position:absolute;inset:0;opacity:0;pointer-events:none}

.amount-card:has(> input[type="radio"]:checked){background:var(--brand);border-color:var(--brand); color: #ffffff;}
.amount-other{gap:10px;justify-content:flex-start;padding:0 14px}
.amount-other span{font-weight:800;font-size:22px}

/* “Other” number blends into card (no inner box) */
.amount-card.amount-other input[type="number"], .amount-card.amount-other input[type="text"]{
  all:unset;font-size:18px;font-weight:700;color:#ffffff;width:110px
}
.amount-card.amount-other input[type="number"]::placeholder, .amount-card.amount-other input[type="text"]::placeholder{color:#9aa7b3}

/* ===== Recurring row ===== */
.checkbox{display:flex;gap:10px;align-items:flex-start;font-weight:600}
.checkbox input{width:auto;margin-top:3px}

/* ===== Actions: Back left / Continue right ===== */
.actions{display:flex;gap:12px;align-items:center;margin-top:14px}
.actions .push-right{margin-left:auto}
.fdbtn{appearance:none;border:1px solid #0082c8;background:#fff;color:#0082c8;padding:10px 16px;border-radius:10px;cursor:pointer;font-weight:500;height:42px; padding: 5px 15px; text-transform: uppercase;
    font-size: 16px;}
.fdbtn:hover{background:#f9fafb}
.fdbtn[disabled]{opacity:.55;cursor:not-allowed}
.fdbtn-primary{background:#0082c8;border-color:#0082c8;color:#fff}
.fdbtn-primary:hover{background:var(--brand-dark)}

/* ===== Tabs for payment method ===== */
.tabs{display:flex;gap:8px;margin:10px 0 12px}
.tab{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;font-weight:800;box-shadow:var(--shadow)}
.tab input{display:none}
.tab.active{border-color:var(--brand);background:#fff3ec}

/* ===== Panels ===== */
.panel{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;margin-top:8px;box-shadow:var(--shadow)}
.muted{background:#fafafa}
.hidden{display:none}

/* ===== Right Aside ===== */
.fcd-aside {
   /* position: relative; */
    background: none;
    border: 0px;
    border-radius: 0px;
    box-shadow: none;
    padding: 0px;
    overflow: hidden;
    height: fit-content;
	  position: sticky;
  top: 160px;
}
.fcd-aside h2
 {
    font-size: 17.5px;
  margin: 0 0 10px;
  font-weight: 500;
  text-align: center;
  line-height: 28px;
  letter-spacing: -.04em;
}
.fcd-badges{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  align-items: center;
  justify-items: center;
  margin-top: 24px;
}

.fcd-badges img{
  max-width: 100%;
  height: 87px;
  display: block;
}

/* Verified badge — center by itself */
.fcd-badges .verified {
  grid-column: 1 / -1;
  justify-self: center;
  height: 150px;
}

.fcd-hero{
  border-radius:12px;margin-top:10px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)
}
.fcd-hero img{display:block;width:100%;height:auto}

.pill-group { display:flex; gap:8px; }
.pill {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border:1px solid var(--border);
  border-radius:9px; background:#fff; cursor:pointer; font-weight:600;
}
.pill input { display:none; }
.pill:has(input:checked) { border-color: var(--brand); background:#fff3ec; }

/* Remove the up/down arrows from the "Other" number input */
.fcd-wrap input[type="number"]::-webkit-inner-spin-button,
.fcd-wrap input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}

.fcd-wrap input[type="number"] {
  -moz-appearance: textfield !important; /* For Firefox */
}

.help.fcd-msg {

  text-align: right;
  font-weight: bold;
  font-size: 16px;

  background-image: linear-gradient(
    225deg,
    #2a64ff 0%,
    #44107a 29%,
    #ff1361 67%,
    #b54b20 100%
  );
  background-size: auto auto;
  background-clip: border-box;
  background-size: 200% auto;
  color: #fff;
  background-clip: text;
  text-fill-color: transparent;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: textclip 2s linear infinite;
}

@keyframes textclip {
  to {
    background-position: 200% center;
  }
}

/* Cloudflare Turnstile Styling */
.fcd-turnstile-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px 0;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
  background: #f9fafb;
  border-radius: 8px;
}

.cf-turnstile {
  margin: 0 auto;
}

/* Ensure Turnstile is visible on mobile */
@media (max-width: 640px) {
  .fcd-turnstile-wrapper {
    padding: 15px 0;
  }
}

/* Loading state for submit button when Turnstile is verifying */
.fdbtn-primary:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}