:root{
  --bg1:#0b1220; --bg2:#111c35; --panel:rgba(16,25,43,.9); --stroke:#243142;
  --muted:#94a3b8; --brand:#2563eb; --accent:#22d3ee;
  --ok:#34d399; --err:#ef4444;
}

@keyframes bgmove{0%{background-position:0 0;}100%{background-position:100% 100%;}}

.form-wrap {
  width:100%;
  max-width:920px;

  padding:28px;
}

.form-wrap label, .form-wrap h3, .form-wrap h2, .form-wrap strong, .form-wrap span, .form-wrap p {
    color: var(--color-text-white);
}

/* Responsive tweaks */
@media (max-width: 768px) {
  .form-wrap{
  width:100%;
  max-width:70%;

  padding:28px;

  margin-right: auto;
  margin-left: auto;
}


}
.form-container{
  background:var(--panel);border:1px solid rgba(255,255,255,.08);
  border-radius:32px;box-shadow:0 15px 50px rgba(0,0,0,.55);
  padding:42px 40px;position:relative;overflow:hidden;
}
.topbar{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:22px}

/* === FIXED UNIVERSAL PROGRESS BAR (DESKTOP + MOBILE) === */
.progress {
  display: flex;
  align-items: center;
  gap: 22px;
  overflow-x: auto !important;       /* must allow scroll */
  overflow-y: hidden;
  width: 100%;                       /* make sure it spans container */
  max-width: 100%;
  padding: 8px 16px;
  position: relative;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  white-space: nowrap;
  scrollbar-width: none;
  -ms-overflow-style: none;
  justify-content: flex-start;
}
.progress::-webkit-scrollbar {
  display: none;
}

/* no background line */
.progress::before {
  display: none;
}

/* individual step icons */
.step {
  flex: 0 0 auto;
  scroll-snap-align: start;          /* ensures step 1 shows from left edge */
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  min-width: 64px;
  z-index: 1;
  user-select: none;
}

.icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: #1e293b;
  display: grid;
  place-items: center;
  color: #9ca3af;
  font-size: 20px;
  transition: 0.35s;
  box-shadow: 0 0 0 4px transparent;
}
.step.active .icon {
background: rgba(6, 50, 144, 0.66);
  color: #fff;
  transform: scale(1.1);
  box-shadow: 0 0 10px #2563eb70;
}
.step.done .icon {
  background: var(--color-primary-light, rgba(100, 181, 246, 0.25));
  box-shadow: 0 0 10px rgba(100, 181, 246, 0.6),
              0 8px 10px rgba(0, 0, 0, 0.25);
}

.step span {
  font-size: 12px;
  color: #9ca3af;
  margin-top: 6px;
  text-align: center;
}

/* smaller tweaks for phones */
@media (max-width: 640px) {
  .icon {
    width: 44px;
    height: 44px;
    font-size: 17px;
  }
  .step span {
    display: none;
  }
}



/* FORM ELEMENTS */
.screen{display:none;opacity:0;transform:translateY(16px);transition:.45s}
.screen.active{
  display:block;
  opacity:1;
  transform:translateY(0); 
}

#summaryBox {
overflow-y: scroll; 
height: 201px;
}
label{display:block;margin:.4rem 0 .35rem;font-weight:600}
input,select,textarea{
  width:100%;padding:12px 13px;border-radius:12px;
  border:1px solid var(--stroke);background:#0f1627;color:#fff;
  transition:border .2s,box-shadow .2s;outline:none;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(37,99,235,.25)
}
textarea{min-height:110px;resize:vertical}

.row{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:720px){
  .row.two{grid-template-columns:1fr 1fr}
}

.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  display:inline-flex;align-items:center;gap:8px;padding:10px 12px;
  border-radius:999px;background:#0f1627;border:1px solid var(--stroke);
  cursor:pointer;user-select:none;transition:.2s;
}

/* Responsive tweaks */
@media (max-width: 768px) {
  .chip {
     border: unset;
     font-size: .8em;
  }
  .chip input {
  width: 14px;
  height: 14px;
  }
  
}
.chip input {
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 6px;
  border: 2px solid #334155;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  cursor: pointer;
}


.chip input::after {
  content: "\f00c";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 10px;
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
  transition: transform 0.18s ease;
}

.chip input:checked {
  border-color: #000;
  background: #000;
}

.chip input:checked::after {
  transform: translate(-50%, -50%) scale(1);
}

.chip:hover{box-shadow:0 0 0 3px rgba(34,211,238,.15)}

.hint{font-size:12px;color:var(--muted)}
.error{font-size:12px;color:var(--err);display:none;margin-top:4px}
.ok{font-size:12px;color:var(--ok);display:none;margin-top:4px}

.buttons {
  display:flex;justify-content:space-between;align-items:center;
  margin-top:14px;gap:10px;flex-wrap:wrap;
}
.btn {
  background:linear-gradient(90deg,var(--brand),var(--accent));
  color:#00111a;border:0;padding:12px 18px;border-radius:12px;
  font-weight:800;cursor:pointer;transition:.25s;flex:1;text-align:center;
}
.btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border:1px solid var(--brand)}

.thankyou{display:none;text-align:center}
.thankyou.active{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;height:43vh; width: 100%;
}
.thankyou i{
  font-size:68px;color:var(--ok);margin-bottom:14px;
  animation:pulse 1.6s infinite
}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.contact-info{margin-top:14px;color:var(--muted);font-size:14px}
.contact-info a{color:var(--accent);text-decoration:none}
.contact-info a:hover{text-decoration:underline}
#confetti{
  position:fixed;inset:0;pointer-events:none;z-index:6
}

/* MOBILE FORM SMALLER TOUCH TARGETS */
@media(max-width:640px){
  .form-container{padding:28px 20px;border-radius:20px;}
  h2{font-size:1.25rem;}
  .buttons{flex-direction:column;align-items:stretch;margin-top:24px;}
  .btn,.btn-ghost{width:100%;padding:14px;font-size:15px;}
  textarea{min-height:125px;}
}

.thankyou {
  opacity: 0;
  transition: opacity .6s ease;
}
.thankyou.active {
  display: flex;
  opacity: 1;
}


.close-form {
  position: absolute;
  top: 24px;
  right: 45px;
  font-size: 1.8rem;
  background: transparent;
  border: none;
  color: var(--text-color, #fff);
  cursor: pointer;
  transition: transform 0.2s ease, color 0.2s ease;
  z-index: 1000;
}

.close-form:hover {
  transform: scale(1.2);
  color: var(--color-primary, #0ea5e9);
}

.form-wrap {
  position: relative;
}
.hidden-form{ 
  opacity: 0;
  visibility: hidden;
}
