/* =========================
   FOUNDER VITALITY - PREMIUM BOOKING UI
========================= */

/* --- Card --- */
.fv-luxury-card{
  max-width: 620px;
  margin: 40px auto;
  padding: 46px;
  border-radius: 18px;
  border: 1px solid rgba(201,162,77,.28);
  background: linear-gradient(180deg, rgba(11,31,51,.92) 0%, rgba(7,18,31,.92) 100%);
  box-shadow: 0 30px 90px rgba(0,0,0,.55);
  position: relative;
  overflow: hidden;
  color: #f8fafc;
}

/* Glow */
.fv-luxury-card:before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(70% 60% at 20% 10%, rgba(201,162,77,.18) 0%, rgba(201,162,77,0) 55%);
  pointer-events:none;
}

/* Inner border */
.fv-luxury-card:after{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  pointer-events:none;
}

/* --- Header --- */
.fv-header h2{
  color: #c9a24d;
  font-size: 22px;
  letter-spacing: .22em;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 10px;
}

.fv-header p{
  text-align: center;
  font-style: italic;
  opacity: .85;
  font-size: 14px;
  margin-bottom: 34px;
}

/* --- Labels --- */
.fv-group label{
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  color: #c9a24d;
  margin-bottom: 10px;
  font-weight: bold;
  letter-spacing: .22em;
}

/* --- Inputs --- */
.fv-luxury-card input:not([type="checkbox"]):not([type="range"]),
.fv-luxury-card select,
.fv-luxury-card textarea{
  width: 100%;
  padding: 13px 14px;
  border-radius: 12px;
  background: rgba(248,250,252,.96);
  border: 1px solid rgba(201,162,77,.22);
  color: #0B1F33;
  font-size: 15px;
  box-shadow: 0 10px 25px rgba(0,0,0,.15);
  transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}

/* Focus premium */
.fv-luxury-card input:focus,
.fv-luxury-card select:focus,
.fv-luxury-card textarea:focus{
  outline: none;
  border-color: rgba(201,162,77,.65);
  box-shadow: 0 0 0 4px rgba(201,162,77,.18), 0 14px 35px rgba(0,0,0,.22);
  transform: translateY(-1px);
}

/* --- SELECT FIX (IMPORTANT) --- */
.fv-luxury-card select{
  height: 52px;
  line-height: 52px;
  padding: 0 44px 0 14px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* Date fix */
.fv-luxury-card input[type="date"]{
  height: 52px;
  line-height: 52px;
  padding: 0 14px;
}

/* --- Checkbox grid --- */
.fv-checkbox-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

/* Checkbox item */
.check-item{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  cursor: pointer;
  transition: .2s ease;
  line-height: 1.2;
  white-space: normal;
}

.check-item:hover{
  border-color: rgba(201,162,77,.35);
  background: rgba(201,162,77,.08);
}

/* Checkbox input */
.check-item input{
  width: 16px;
  height: 16px;
  margin: 0;
}

/* --- Range slider --- */
#fv-urgency{
  width: 100%;
  accent-color: #c9a24d;
  height: 6px;
}

/* --- Button Premium Upgrade --- */
.fv-btn-gold {
  width: 100%;
  background: linear-gradient(135deg, #c9a24d, #e0bc6b);
  color: #0B1F33;
  padding: 18px;
  border: none;
  font-weight: 700;
  letter-spacing: 2px;
  cursor: pointer;
  transition: all 0.3s ease;
  border-radius: 999px;
  box-shadow: 0 10px 30px rgba(201,162,77,0.3);
}

.fv-btn-gold:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 40px rgba(201,162,77,0.4);
}

.fv-btn-gold:active {
  transform: translateY(0);
}

/* --- Message --- */
#fv-message{
  margin-top: 18px;
  text-align: center;
  color: #c9a24d;
  font-weight: 700;
}

/* --- Layout --- */
.fv-row{
  display: flex;
  gap: 18px;
}

.fv-group{
  margin-bottom: 22px;
}

/* --- Mobile --- */
@media (max-width: 520px){
  .fv-row{
    flex-direction: column;
    gap: 0;
  }

  .fv-checkbox-grid{
    grid-template-columns: 1fr;
  }

  .fv-luxury-card{
    padding: 30px;
  }
}
/* ===== Select readability fix ===== */

/* 1) Evita texto cortado: usa padding vertical real y line-height normal */
.fv-luxury-card select{
  height: 52px !important;
  line-height: 1.2 !important;          /* NO 52px */
  padding: 14px 44px 14px 14px !important;
  color: #0B1F33 !important;            /* texto dentro del select */
  background-color: rgba(248,250,252,.96) !important;
  border: 1px solid rgba(201,162,77,.22) !important;
}

/* 2) Placeholder "Select your role" (cuando value="") se vea un poco gris */
.fv-luxury-card select:invalid{
  color: rgba(11,31,51,.55) !important;
}

/* 3) Dropdown options: fuerza texto oscuro sobre fondo blanco */
.fv-luxury-card select option{
  color: #0B1F33 !important;
  background: #ffffff !important;
}

/* 4) Asegura que el texto no quede tapado por estilos del theme */
.fv-luxury-card select,
.fv-luxury-card option{
  text-shadow: none !important;
}

/* (Opcional) si Astra mete un color raro global */
.fv-luxury-card select *{
  color: #0B1F33 !important;
}
.fv-luxury-card select{
  -webkit-appearance: menulist !important;
  appearance: menulist !important;
}


/* Micropcopy del button */
.fv-microcopy {
  text-align: center;
  font-size: 12px;
  opacity: 0.75;
  margin-top: 14px;
  letter-spacing: 0.05em;
}
.fv-microcopy {
  text-align: center !important;
}
/* Fix microcopy centering (Astra / flex-safe) */
.fv-microcopy{
  display: block !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}

/* If a parent is flex, this ensures centering */
.fv-luxury-card .fv-microcopy{
  align-self: center !important;
}