/* =============================================================================
   cliente_vip.css — UX focada em confiança, tipografia e fluidez
   v13 · 2025-08-30
   - Ícones dentro de botões travados (18×18) e herdando a cor do texto
   - Botões com texto sem quebra (nowrap) e centralizados; estados loading/sucesso
   - Coração do topo/título com tamanho controlado (sem posição absoluta)
   - Grid 1 coluna ≤820px; inputs/botões confortáveis no mobile
   - Botões "Buscar" e "Salvar Meus Dados" centralizados no mobile
   ============================================================================= */

:root{
  --pg-purple: #69488E;
  --pg-purple-2: #563474;
  --pg-peach:  #D59B68;
  --pg-taupe:  #d0c2c3;
  --pg-light-gray: #e0dce2;

  --bg: #fafafa;
  --card: #ffffff;
  --bord: #eeeeee;
  --txt: #222;
  --sub: #6f6177;

  --font-sys: system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, Cantarell, "Helvetica Neue", Arial, "Noto Sans";
  --fs-100: 12.5px;
  --fs-200: 13px;
  --fs-300: 14px;
  --fs-400: 15px;
  --fs-500: 16px;
  --fs-600: 18px;

  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --rad: 14px;
  --rad-sm: 10px;
  --shadow-1: 0 1px 2px rgba(0,0,0,.04);
  --shadow-2: 0 6px 14px rgba(105,72,142,.18);

  --focus-ring: 0 0 0 3px rgba(105,72,142,.16);
}

*{ box-sizing:border-box }
html,body{ height:100% }
body{
  margin:0;
  font-family: var(--font-sys);
  font-size: var(--fs-400);
  line-height: 1.45;
  background: var(--bg);
  color: var(--txt);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
}

/* ===== Container / Header ===== */
.vip-container{ max-width: 1000px; margin: 0 auto; padding: 22px 14px; }

.vip-header{
  display:flex; align-items:center; justify-content:center; gap:14px; margin-bottom: 14px; flex-wrap:wrap;
}
.brand{ display:flex; align-items:center; gap:16px; }
.vip-logo{ height: 44px; display:block; max-width:100%; object-fit:contain; }

/* Coração controlado: nunca absoluto, limite de tamanho */
.vip-heart{
  height: 52px; max-height: 52px; width:auto; display:block; opacity:.97;
  object-fit:contain; position: static; filter: drop-shadow(0 1px 2px rgba(0,0,0,.15));
}

.secure-badge{
  display:inline-flex; align-items:center; gap:8px;
  background:#f8f5fb; border:1px solid #efe8f6; color:#43324e;
  padding:8px 14px; border-radius: 999px; font-size: var(--fs-300);
}

/* ===== Cards ===== */
.vip-card{
  background: var(--card);
  border:1px solid var(--bord);
  border-radius: var(--rad);
  padding: 14px;
  margin-bottom: 12px;
  box-shadow: var(--shadow-1);
  position: relative;
}
.vip-card::before{
  content:"";
  position:absolute; left:0; top:0; right:0; height:3px;
  background: linear-gradient(90deg, var(--pg-purple), #8d6db3 60%, var(--pg-peach));
  border-top-left-radius: var(--rad);
  border-top-right-radius: var(--rad);
}
.vip-card-header{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom: 10px; }
.vip-card-header h2{ font-size: var(--fs-500); margin:0; color:#333; }

/* ===== Busca ===== */
.vip-search label{
  display:block; font-size: var(--fs-300); color:#4a3a54; margin-bottom:6px; font-weight:600;
}
.vip-search .row{ display:flex; gap:8px; align-items:flex-end; }
.vip-search input{
  flex:1;
  padding:12px 14px;
  border:1px solid #ddd; border-radius: var(--rad-sm);
  font-size: var(--fs-400); background:#fff; text-align: left;
  transition: border .2s ease, box-shadow .2s ease, transform .2s ease;
}
.vip-search input:focus{ outline:none; border-color: var(--pg-purple); box-shadow: var(--focus-ring); }

/* ===== Botões ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 16px; border-radius: var(--rad-sm); cursor:pointer; border:1px solid transparent;
  font-weight:700; transition: .2s ease; user-select:none;
  white-space: nowrap; line-height: 1; /* evita quebra de texto e “pulo” vertical */
}
.btn-primary{
  background: var(--pg-purple); color:#fff; border-color: var(--pg-purple);
  box-shadow: var(--shadow-2);
}
.btn-primary:hover{ filter: brightness(0.96); transform: translateY(-1px); }
.btn-primary:active{ transform: translateY(0); }

/* Ícone “coração” declarativo (se usado dentro de botões) */
.btn-heart{ height:30px; width:30px; display:inline-block; }
.vip-form .submit-row .btn .btn-heart{
  width:30px;
  height:30px;
  flex:0 0 30px;
  transform:scale(2);
  transform-origin:center;
}
.vip-form .submit-row .btn .btn-heart.is-spinning{
  animation: vipHeartSpin .9s linear infinite;
}

/* ÍCONES DENTRO DO BOTÃO (fix): qualquer SVG/IMG vira 18×18 e herda a cor do texto */
.btn .btn-ico,
.btn svg,
.btn img{
  width:18px; height:18px; flex:0 0 18px;
  display:inline-block; vertical-align:middle; object-fit:contain;
  fill: currentColor;
}
.btn svg path{ fill: currentColor; }
.btn-text{ display:inline-block; line-height:1 }

/* Estado loading no botão */
.btn.is-loading{ opacity:.85; pointer-events:none; position:relative }
.btn.is-loading::after{
  content:""; width:16px; height:16px; border:2px solid #fff; border-top-color: transparent;
  border-radius:50%; margin-left:8px; display:inline-block; animation:spin .8s linear infinite;
}
@keyframes spin{ to{ transform: rotate(360deg) } }
@keyframes vipHeartSpin{ to{ transform: rotate(360deg) } }

/* Botão WhatsApp */
.btn-wa{
  background: #25D366; color:#fff; border-color:#25D366;
  box-shadow: 0 6px 14px rgba(37,211,102,.25);
  padding: 12px 16px;
}
.btn-wa:hover{ filter: brightness(0.96); transform: translateY(-1px) }
.btn-wa:active{ transform: translateY(0) }

/* ===== Alertas / Callouts ===== */
.vip-alert{
  margin-top: 12px; padding:12px 14px; border-radius: var(--rad-sm);
  font-size: var(--fs-300); color:#333; background:#f2f2f2; border:1px solid #efefef;
}
.vip-alert.error{ background:#ffe5e5; color:#8a1f1f; border-color:#ffcccc }
.vip-alert.success{ background:#e7ffe9; color:#1e7b39; border-color:#bfecc7 }

.vip-callout{
  display:flex; flex-direction:column; gap:10px;
  background: #f6fff9; border:1px solid #d9f3e3; border-left:5px solid #2ecc71;
  padding: 14px; border-radius: 12px; color:#1f7a43;
}
.vip-callout h4{ margin:0; font-size: var(--fs-500) }
.vip-callout p{ margin:0; font-size: var(--fs-300); color:#2c7a55 }
.vip-callout .wa-row{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.vip-callout .wa-number{
  font-size: var(--fs-300);
  color:#185f3f;
  text-align:center;
}
.vip-callout .meta-verified{
  position:relative;
  display:inline-flex;
  width:18px;
  height:18px;
  margin-left:6px;
  vertical-align:middle;
}
.vip-callout .meta-verified__ring,
.vip-callout .meta-verified__check{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}
.vip-callout .meta-verified__ring{
  background:linear-gradient(180deg,#31a4ff 0%, #0a84ff 100%);
  border-radius:50%;
  box-shadow:0 2px 6px rgba(10,132,255,.28);
}
.vip-callout .meta-verified__check{
  color:#fff;
  font-size:12px;
  font-weight:900;
  line-height:1;
}

/* ===== Lista de Itens ===== */
.vip-grid{ display:grid; grid-template-columns: 1.1fr 0.9fr; gap: 14px }

.vip-items{ display:flex; flex-direction: column; gap:10px }
.vip-item{
  display:flex; gap:12px; padding:10px; border:1px solid var(--bord);
  border-radius:12px; background:#fff; transition: box-shadow .2s ease, transform .15s ease;
}
.vip-item:hover{ transform: translateY(-1px); box-shadow: 0 4px 10px rgba(0,0,0,.06) }
.thumb{
  width:56px; height:56px; border-radius:10px; overflow:hidden;
  background:linear-gradient(180deg,#f6f4f7,#f0ecf3);
  flex:0 0 56px; display:flex; align-items:center; justify-content:center; border:1px solid #eee;
}
.thumb img{ width:56px; height:56px; object-fit:cover }
.thumb-ph{ width:42px; height:42px; background:#eae4ef; border-radius:8px }
.info .title{ font-weight:800; margin-bottom:2px; font-size: var(--fs-300); color:#32243c }
.info .sub{ color: var(--sub); font-size: var(--fs-200) }

/* ===== Formulário ===== */
.vip-form .grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 6px }
.vip-form .grid .wide{ grid-column: span 2 }
.vip-form .grid .small{ max-width:120px }
.vip-form .fg{ display:flex; flex-direction:column }
.vip-form .fg label{ display:block; font-size: var(--fs-200); color:#5b4b65; margin-bottom:6px; font-weight:700; text-align:left }
.vip-form .fg input{
  width:100%;
  padding:12px 14px;
  border:1px solid #ddd; border-radius: var(--rad-sm);
  font-size: var(--fs-400); background:#fff; text-align: left;
  -webkit-appearance: none;
  transition: border .2s ease, box-shadow .2s ease;
}
.vip-form .fg input:focus{ outline:none; border-color: var(--pg-purple); box-shadow: var(--focus-ring) }
.vip-form .fg input::placeholder{ color:#9e8aa9; opacity:.9 }

/* Submit */
.vip-form .submit-row{ display:flex; justify-content:center; align-items:center; margin-top: 12px }
.vip-form button[type="submit"]{ margin: 12px auto 0; display:inline-flex }

/* ===== Título estilizado (opcional — usado em “Atualize Seu Pedido”) ===== */
.vip-section-title{
  display:flex; align-items:center; gap:12px; margin:6px 0 12px; position:relative; z-index:1;
}
.vip-section-title .title-wrap{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  white-space:nowrap;
}
.vip-section-title .title-heart{
  width:34px; height:34px; max-height:34px; object-fit:contain;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.15));
}
.vip-section-title .text{
  font-weight:800; font-size:1.12rem; color:#4b3867; letter-spacing:.2px; white-space:nowrap;
}
.vip-section-title .line{
  flex:1; height:1px; border-radius:1px;
  background:linear-gradient(90deg, rgba(105,72,142,0) 0%, rgba(105,72,142,.35) 25%, rgba(213,155,104,.45) 50%, rgba(105,72,142,.35) 75%, rgba(105,72,142,0) 100%);
}

/* ===== Acessibilidade / Focus ===== */
.btn:focus-visible,
.vip-search input:focus-visible,
.vip-form .fg input:focus-visible{ outline: none; box-shadow: var(--focus-ring) }
@media (prefers-reduced-motion: reduce){
  .btn, .vip-item, .vip-search input, .vip-form .fg input{ transition: none !important }
}

/* ===== Responsivo ===== */
@media (max-width: 820px){
  .vip-grid{ grid-template-columns: 1fr }
  .vip-card{ padding: 12px }
  .vip-search .row{ flex-direction: column; align-items: stretch }
  .vip-search input,
  .vip-form .fg input,
  .btn{ min-height: 48px }
  .vip-form .fg input{ font-size: 16px } /* melhora teclado iOS/Android */

  /* Botões centralizados e com largura amigável no mobile */
  .vip-search .row .btn{
    align-self: center;
    width: clamp(160px, 60%, 280px);
    margin-top: 8px;
  }

  .vip-search .row .btn .btn-heart,
  .vip-form .submit-row .btn .btn-heart{ height: 30px; width: 30px; flex:0 0 30px }
  .vip-form .grid{ grid-template-columns: 1fr }
  .vip-form .grid .wide{ grid-column: auto }
  .vip-form .addr-details.grid{ grid-template-columns: minmax(0, 1fr) 92px }
  .vip-form .addr-details.grid .wide,
  .vip-form .addr-details.grid .fg-bairro{ grid-column: 1 / -1 }
  .vip-form .addr-details.grid .fg-city{ grid-column: 1 }
  .vip-form .addr-details.grid .fg-uf{ grid-column: 2 }
  .vip-heart{ height: 56px; max-height:56px }
  .vip-section-title{ gap:10px }
  .vip-section-title .title-wrap{ gap:8px }
  .vip-section-title .title-heart{ width:36px; height:36px; max-height:36px }
  .vip-header{ gap:10px }
}

@media (max-width: 560px){
  /* Força botões a ocuparem a largura toda quando necessário */
  .vip-form .submit-row .btn{ width:100% }
}

@media (max-width: 380px){
  .brand{ gap:10px }
  .vip-logo{ height:36px }
  .vip-heart{ height:44px; max-height:44px }
  .thumb{ width:52px; height:52px }
  .thumb img{ width:52px; height:52px }
}

/* ===== Estados de validação ===== */
.input-error{ border-color:#E74C3C !important; box-shadow: 0 0 0 3px rgba(231,76,60,.12) !important }
.input-success{ border-color:#27AE60 !important; box-shadow: 0 0 0 3px rgba(39,174,96,.12) !important }

.vip-footer{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  text-align:center;
  color:#6f6177;
  font-size:13px;
  padding:8px 0 2px;
}
.vip-footer a{
  color:#6f6177;
  text-decoration:none;
}
.vip-footer a:hover{
  text-decoration:underline;
}
