:root{
  /* Keep your exact brand colors */
  --pi-accent1:#C53232; /* primary */
  --pi-accent2:#8F2A2A; /* secondary */

  /* Make the form brighter + whiter */
  --pi-bg1:#f7f7fb;
  --pi-bg2:#ffffff;

  --pi-card: rgba(255,255,255,.92);
  --pi-border: rgba(15,23,42,.10);

  --pi-text: rgba(15,23,42,.92);
  --pi-muted: rgba(15,23,42,.62);

  --pi-danger:#fb7185;
  --pi-ok:#34d399;

  /* Soft brand glow */
  --pi-glow: rgba(197,50,50,.18);
  --pi-glow-2: rgba(143,42,42,.12);
}

.piwheel-if-wrap{
  position:relative;
  padding:24px;
  border-radius:24px;
  overflow:hidden;

  /* Bright, clean base with brand ambiance */
  background:
    radial-gradient(900px 520px at 10% 10%, rgba(197,50,50,.18), transparent 62%),
    radial-gradient(900px 520px at 92% 0%, rgba(143,42,42,.12), transparent 60%),
    radial-gradient(900px 560px at 55% 120%, rgba(197,50,50,.10), transparent 58%),
    linear-gradient(160deg, var(--pi-bg1), var(--pi-bg2));

  box-shadow: 0 20px 60px rgba(2,6,23,.12);
}

.piwheel-if-wrap::before{
  content:"";
  position:absolute;
  inset:-2px;

  /* Subtle brand border glow (not dark) */
  background: linear-gradient(120deg,
    rgba(197,50,50,.35),
    rgba(255,255,255,.55),
    rgba(143,42,42,.28)
  );

  filter: blur(18px);
  opacity:.55;
  z-index:0;
}

.piwheel-if{
  position:relative;
  z-index:1;
  color: var(--pi-text);
  backdrop-filter: blur(10px);

  /* Whiter card */
  background: var(--pi-card);
  border: 1px solid var(--pi-border);
  border-radius: 22px;
  padding: 22px;

  box-shadow: 0 14px 40px rgba(2,6,23,.10);
}

.piwheel-if-head{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom: 16px;
}

.piwheel-if-badge{
  width:max-content;
  font-weight:700;
  letter-spacing:.3px;
  padding:6px 10px;
  border-radius: 999px;
  border:1px solid rgba(197,50,50,.22);
  background: rgba(197,50,50,.06);
  transform: translateZ(0);
  color: rgba(15,23,42,.85);
}

.piwheel-if h3{
  margin:0;
  font-size: 24px;
  line-height: 1.15;
}

.piwheel-if p{
  margin:0;
  color: var(--pi-muted);
}

.piwheel-if-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 720px){
  .piwheel-if-grid{ grid-template-columns: 1fr; }
}

.field{ display:flex; flex-direction:column; gap:8px; }
.field.wide{ grid-column: 1 / -1; }

label{ font-size: 13px; color: var(--pi-muted); }

input, select, textarea{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.12);

  /* Bright field surface */
  background:
    radial-gradient(140px 70px at 10% 0%, rgba(197,50,50,.08), transparent 62%),
    rgba(255,255,255,.92);

  color: rgba(15,23,42,.92);
  padding: 12px 12px;
  outline: none;
  transition: transform .15s ease, border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

input::placeholder, textarea::placeholder{
  color: rgba(15,23,42,.45);
}

textarea{ resize: vertical; min-height: 110px; }

/* ---------- Bespoke Select (Dropdown) ---------- */
select{
  cursor:pointer;

  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;

  padding-right: 44px;

  background-image:
    radial-gradient(18px 18px at 14px 14px, rgba(197,50,50,.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.75), rgba(255,255,255,0)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M7 10l5 5 5-5' stroke='%238F2A2A' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");

  background-repeat: no-repeat;
  background-position:
    0 0,
    0 0,
    right 14px center;

  background-size:
    100% 100%,
    100% 100%,
    18px 18px;
}

select:hover{
  border-color: rgba(197,50,50,.35);
  box-shadow: 0 10px 28px rgba(2,6,23,.10);
  transform: translateY(-1px);
  background:
    radial-gradient(140px 70px at 10% 0%, rgba(197,50,50,.10), transparent 62%),
    rgba(255,255,255,.98);
}

select option{
  background: #ffffff;
  color: rgba(15,23,42,.92);
}
select option[disabled]{
  color: rgba(15,23,42,.45);
}

input:focus, select:focus, textarea:focus{
  border-color: rgba(197,50,50,.55);
  box-shadow: 0 0 0 4px var(--pi-glow);
  transform: translateY(-1px);
  background:
    radial-gradient(140px 70px at 10% 0%, rgba(197,50,50,.10), transparent 62%),
    rgba(255,255,255,1);
}

.field[data-invalid="1"] input,
.field[data-invalid="1"] select,
.field[data-invalid="1"] textarea{
  border-color: rgba(251,113,133,.75);
  box-shadow: 0 0 0 4px rgba(251,113,133,.12);
}

.terms{
  margin-top: 2px;
  padding-top: 6px;
}

.check{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding: 12px;
  border-radius: 16px;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.86);
  box-shadow: 0 10px 24px rgba(2,6,23,.06);
}

.check input{ width:18px; height:18px; margin-top:2px; accent-color: var(--pi-accent1); }

.actions{
  display:flex;
  gap: 12px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  margin-top: 6px;
}

.btn{
  position:relative;
  border:0;
  border-radius: 16px;
  padding: 12px 16px;
  color: white;
  font-weight: 800;
  cursor: pointer;

  /* Your exact colors */
  background: linear-gradient(110deg, var(--pi-accent1), var(--pi-accent2));

  box-shadow: 0 14px 34px rgba(197,50,50,.22), 0 18px 46px rgba(2,6,23,.12);
  overflow:hidden;
  transform: translateZ(0);
}

.btn:disabled{
  opacity:.55;
  cursor:not-allowed;
  filter: grayscale(.15);
  box-shadow:none;
}

.btn .btn-glow{
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.55), transparent 55%);
  transform: translateX(-35%);
  opacity: .95;
  transition: transform .35s ease;
  pointer-events:none;
}

.btn:hover .btn-glow{
  transform: translateX(35%);
}
.btn{
  position: relative;
  color: #ffffff;
}

/* Ensure text is always visible */
.btn .btn-label{
  position: relative;
  z-index: 2;
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(0,0,0,.35);
}

/* Keep glow behind text */
.btn .btn-glow{
  z-index: 1;
  pointer-events: none;
}

.msg{
  flex: 1 1 260px;
  min-height: 20px;
  color: var(--pi-muted);
}

.msg.ok{ color: var(--pi-ok); }
.msg.err{ color: var(--pi-danger); }

.piwheel-if-progress{
  grid-column: 1 / -1;
  height: 8px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(15,23,42,.04);
  overflow:hidden;
}

#piwheel-progress-bar{
  display:block;
  height:100%;
  width: 0%;
  border-radius: 999px;

  /* Your exact colors */
  background: linear-gradient(90deg, rgba(197,50,50,.95), rgba(143,42,42,.95));

  transition: width .25s ease;
}

.piwheel-pop{
  animation: piwheelPop .35s ease both;
}

@keyframes piwheelPop{
  0%{ transform: scale(.985); opacity:.85; }
  100%{ transform: scale(1); opacity:1; }
}