/* ============================================
   NAYT PROD - Forms (Multi-step + Custom)
   ============================================ */

/* ===== FORM CONTAINER ===== */
.form-wrapper{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:var(--sp-10);
  position:relative;
  overflow:hidden;
}
.form-wrapper::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:var(--gradient-brand);
  transform-origin:left;
}
@media (max-width:768px){.form-wrapper{padding:var(--sp-6)}}

.form-header{
  margin-bottom:var(--sp-10);
  text-align:center;
}
.form-header h3{
  font-size:var(--fs-3xl);
  margin-bottom:var(--sp-3);
}
.form-header p{
  color:var(--text-muted);
  font-size:var(--fs-base);
}

/* ===== PROGRESS BAR (multi-step) ===== */
.form-progress{
  margin-bottom:var(--sp-10);
}
.progress-steps{
  display:flex;
  justify-content:space-between;
  position:relative;
  margin-bottom:var(--sp-4);
}
.progress-steps::before{
  content:'';
  position:absolute;
  top:18px;
  left:0;
  right:0;
  height:2px;
  background:var(--border);
  z-index:0;
}
.progress-fill{
  position:absolute;
  top:18px;
  left:0;
  height:2px;
  background:var(--gradient-brand);
  z-index:1;
  transition:width .5s var(--ease);
  width:0%;
}
.progress-step{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--sp-2);
  flex:1;
}
.progress-circle{
  width:36px;
  height:36px;
  border-radius:50%;
  background:var(--bg-card);
  border:2px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-mono);
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--text-muted);
  transition:all var(--t-base);
}
.progress-step.active .progress-circle{
  background:var(--gradient-brand);
  border-color:transparent;
  color:var(--white);
  box-shadow:0 0 0 6px rgba(0,169,157,.15);
}
.progress-step.completed .progress-circle{
  background:var(--teal);
  border-color:transparent;
  color:var(--white);
}
.progress-step.completed .progress-circle::before{
  content:'✓';
  font-size:var(--fs-base);
}
.progress-step.completed .progress-circle span{display:none}
.progress-label{
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--text-dim);
  text-align:center;
}
@media (max-width:600px){.progress-label{display:none}}
.progress-step.active .progress-label,
.progress-step.completed .progress-label{color:var(--white)}

/* ===== FORM STEPS ===== */
.form-step{
  display:none;
  animation:fadeInUp .5s var(--ease);
}
.form-step.active{display:block}

.form-step-title{
  font-family:var(--font-display);
  font-size:var(--fs-2xl);
  color:var(--white);
  margin-bottom:var(--sp-2);
}
.form-step-subtitle{
  color:var(--text-muted);
  font-size:var(--fs-sm);
  margin-bottom:var(--sp-8);
}

/* ===== FORM GROUP ===== */
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--sp-4);
}
@media (max-width:600px){.form-row{grid-template-columns:1fr}}
.form-row.cols-3{grid-template-columns:repeat(3,1fr)}
@media (max-width:768px){.form-row.cols-3{grid-template-columns:1fr}}

.form-group{
  position:relative;
  margin-bottom:var(--sp-5);
}

.form-label{
  display:block;
  font-family:var(--font-mono);
  font-size:var(--fs-xs);
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:var(--sp-2);
  font-weight:500;
}
.form-label .required{color:var(--teal);margin-left:4px}

.form-input,
.form-textarea,
.form-select{
  width:100%;
  padding:1rem 1.25rem;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  color:var(--white);
  font-family:var(--font-body);
  font-size:var(--fs-base);
  transition:all var(--t-base);
}
.form-input:focus,
.form-textarea:focus,
.form-select:focus{
  outline:none;
  border-color:var(--teal);
  background:rgba(0,169,157,.04);
  box-shadow:0 0 0 4px rgba(0,169,157,.1);
}
.form-input::placeholder,
.form-textarea::placeholder{color:var(--text-dim)}

.form-textarea{
  resize:vertical;
  min-height:120px;
  font-family:var(--font-body);
}

.form-select{
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23A3A3A3' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 1rem center;
  padding-right:2.5rem;
  cursor:pointer;
}
.form-select option{background:var(--bg-card);color:var(--white)}

/* Floating label variant */
.form-floating{
  position:relative;
}
.form-floating .form-input,
.form-floating .form-textarea{
  padding-top:1.4rem;
  padding-bottom:.6rem;
}
.form-floating .form-label{
  position:absolute;
  top:1rem;
  left:1.25rem;
  margin:0;
  pointer-events:none;
  transition:all var(--t-fast);
  text-transform:none;
  letter-spacing:0;
  font-family:var(--font-body);
  font-size:var(--fs-base);
  color:var(--text-dim);
}
.form-floating .form-input:focus + .form-label,
.form-floating .form-input:not(:placeholder-shown) + .form-label,
.form-floating .form-textarea:focus + .form-label,
.form-floating .form-textarea:not(:placeholder-shown) + .form-label{
  top:.4rem;
  font-size:var(--fs-xs);
  color:var(--teal);
  font-family:var(--font-mono);
  letter-spacing:.1em;
  text-transform:uppercase;
}

/* ===== CHECKBOX & RADIO (custom) ===== */
.form-check{
  display:flex;
  align-items:flex-start;
  gap:var(--sp-3);
  cursor:pointer;
  padding:var(--sp-2) 0;
  user-select:none;
}
.form-check input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.form-check-box{
  width:22px;
  height:22px;
  border:2px solid var(--border-strong);
  border-radius:6px;
  flex-shrink:0;
  margin-top:1px;
  position:relative;
  transition:all var(--t-base);
}
.form-check input:checked + .form-check-box{
  background:var(--gradient-brand);
  border-color:transparent;
}
.form-check input:checked + .form-check-box::after{
  content:'';
  position:absolute;
  left:6px;
  top:2px;
  width:6px;
  height:11px;
  border:2px solid var(--white);
  border-top:0;
  border-left:0;
  transform:rotate(45deg);
}
.form-check-label{
  color:var(--text);
  font-size:var(--fs-sm);
  line-height:1.6;
}
.form-check-label a{color:var(--teal);text-decoration:underline}

/* Radio */
.form-radio .form-check-box{border-radius:50%}
.form-radio input:checked + .form-check-box::after{
  content:'';
  position:absolute;
  inset:4px;
  background:var(--white);
  border-radius:50%;
  border:none;
  transform:none;
}

/* ===== OPTION CARDS (visual radio) ===== */
.option-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:var(--sp-3);
  margin-bottom:var(--sp-5);
}
.option-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.option-grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:768px){
  .option-grid,.option-grid.cols-3,.option-grid.cols-4{grid-template-columns:1fr 1fr}
}
@media (max-width:480px){
  .option-grid,.option-grid.cols-3,.option-grid.cols-4{grid-template-columns:1fr}
}

.option-card{
  position:relative;
  cursor:pointer;
}
.option-card input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.option-card-content{
  padding:var(--sp-5);
  background:rgba(255,255,255,.03);
  border:1.5px solid var(--border);
  border-radius:var(--r-md);
  transition:all var(--t-base);
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--sp-2);
  min-height:100px;
  justify-content:center;
}
.option-card:hover .option-card-content{
  border-color:var(--border-strong);
  background:rgba(255,255,255,.05);
}
.option-card input:checked + .option-card-content{
  background:rgba(0,169,157,.08);
  border-color:var(--teal);
  box-shadow:0 0 0 4px rgba(0,169,157,.1);
}
.option-card-icon{
  width:32px;
  height:32px;
  color:var(--text-muted);
  transition:color var(--t-base);
}
.option-card input:checked + .option-card-content .option-card-icon{color:var(--teal)}
.option-card-label{
  font-size:var(--fs-sm);
  font-weight:500;
  color:var(--white);
}
.option-card-desc{
  font-size:var(--fs-xs);
  color:var(--text-dim);
}

/* ===== FORM ACTIONS ===== */
.form-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:var(--sp-4);
  margin-top:var(--sp-8);
  padding-top:var(--sp-8);
  border-top:1px solid var(--border);
}
.form-actions .btn{min-width:140px}
@media (max-width:520px){
  .form-actions{flex-direction:column-reverse}
  .form-actions .btn{width:100%}
}

/* ===== FORM ERROR ===== */
.form-error{
  display:none;
  margin-top:var(--sp-2);
  font-size:var(--fs-xs);
  color:#ff6b6b;
  font-family:var(--font-mono);
}
.form-group.has-error .form-input,
.form-group.has-error .form-textarea,
.form-group.has-error .form-select{
  border-color:#ff6b6b;
}
.form-group.has-error .form-error{display:block}

/* ===== SUCCESS STATE ===== */
.form-success{
  display:none;
  text-align:center;
  padding:var(--sp-12) var(--sp-6);
}
.form-success.active{display:block;animation:fadeInUp .6s var(--ease)}
.success-icon{
  width:100px;
  height:100px;
  margin:0 auto var(--sp-6);
  border-radius:50%;
  background:var(--gradient-brand);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  animation:scaleIn .6s var(--ease-bounce);
}
.success-icon::after{
  content:'';
  width:30px;
  height:50px;
  border:4px solid var(--white);
  border-top:0;
  border-left:0;
  transform:rotate(45deg) translate(-2px,-8px);
}
.form-success h3{
  font-size:var(--fs-3xl);
  margin-bottom:var(--sp-3);
}
.form-success p{
  color:var(--text-muted);
  font-size:var(--fs-base);
  max-width:480px;
  margin:0 auto var(--sp-8);
}

/* ===== FORM LOADER ===== */
.form-loader{
  display:none;
  align-items:center;
  gap:var(--sp-2);
}
.btn.loading .form-loader{display:flex}
.btn.loading .btn-text{display:none}
.spinner{
  width:18px;
  height:18px;
  border:2px solid rgba(255,255,255,.3);
  border-top-color:var(--white);
  border-radius:50%;
  animation:rotate .6s linear infinite;
}

/* ===== UPLOAD AREA ===== */
.upload-area{
  border:2px dashed var(--border-strong);
  border-radius:var(--r-md);
  padding:var(--sp-8);
  text-align:center;
  cursor:pointer;
  transition:all var(--t-base);
  background:rgba(255,255,255,.02);
}
.upload-area:hover{
  border-color:var(--teal);
  background:rgba(0,169,157,.04);
}
.upload-area svg{
  width:40px;
  height:40px;
  color:var(--text-muted);
  margin:0 auto var(--sp-3);
}
.upload-area p{
  color:var(--text);
  font-size:var(--fs-sm);
  margin-bottom:var(--sp-1);
}
.upload-area span{
  color:var(--text-dim);
  font-size:var(--fs-xs);
}

/* ===== CONTACT GRID (form + info) ===== */
.contact-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:var(--sp-12);
  align-items:start;
}
@media (max-width:1024px){.contact-grid{grid-template-columns:1fr}}

.quick-contact{
  display:flex;
  flex-direction:column;
  gap:var(--sp-3);
  margin-top:var(--sp-6);
}
.quick-contact-btn{
  display:flex;
  align-items:center;
  gap:var(--sp-4);
  padding:var(--sp-4) var(--sp-5);
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  color:var(--white);
  transition:all var(--t-base);
}
.quick-contact-btn:hover{
  border-color:var(--teal);
  transform:translateX(4px);
}
.quick-contact-btn .qc-icon{
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--gradient-brand-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--teal);
  flex-shrink:0;
}
.quick-contact-btn .qc-icon svg{width:18px;height:18px}
.qc-info h6{
  font-size:var(--fs-sm);
  margin-bottom:2px;
  font-family:var(--font-body);
}
.qc-info span{
  font-size:var(--fs-xs);
  color:var(--text-dim);
}
