/* ================================
   VLPRICE — Registro (Tema Claro)
   ================================ */

:root{
  --bg: #ffffff;
  --panel: #ffffff;
  --muted: #555;
  --text: #0f0f10;
  --primary: #ff7a00;
  --primary-700: #ff5a00;
  --outline: #e9e9ee;
  --shadow: 0 10px 30px rgba(16,24,40,.08);
  --overlay: rgba(17, 24, 39, .45);
}

*{ box-sizing: border-box; }
html, body{ margin:0; padding:0; }
img{ max-width: 100%; display:block; }
a{ color: inherit; text-decoration: none; }

/* Base */
body.is-landing{
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
  background:
    radial-gradient(900px 600px at 10% -10%, rgba(255,122,0,.05), transparent 50%),
    radial-gradient(800px 500px at 90% -20%, rgba(255,122,0,.04), transparent 55%),
    var(--bg);
  color: var(--text);
  line-height: 1.55;
}

/* Layout helpers */
.container{ width: min(1120px, 92vw); margin: 0 auto; display:flex; min-height: calc(100vh - 90px); align-items:center; }
.primary-color{ color: var(--primary); }
.underline{ text-decoration: underline; text-decoration-color: rgba(255,122,0,.35); text-underline-offset: 4px; }
.link{ color: var(--primary); font-weight: 600; }

/* Nav */
#nav{
  position: sticky; top:0; z-index:100; display:flex; align-items:center; justify-content:space-between;
  padding: 0px 24px; background:transparent; border-bottom: 1px solid transparent; transition: background .25s, border .25s;
}

.btn{
  display: inline-flex; align-items: center; justify-content: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 14px;
  border: 1px solid var(--outline);
  font-weight: 600;
  text-decoration: none;
  box-shadow: var(--shadow);
  transition: transform .15s ease, filter .15s ease, background .15s ease;
  cursor: pointer;
  margin-top: 20px;
}
.btn-lg{ padding: 14px 20px; border-radius: 16px; font-size: 1.05rem; }

.btn-entrar{
  background: linear-gradient(180deg, var(--primary), var(--primary-700));
  color: #fff !important;
  border-color: transparent;
}
.btn-entrar:hover{ filter: brightness(1.03); transform: translateY(-1px); }


/* Card */
.box{
  width: 100%; max-width: 520px;
  position: relative;
  margin: 0px auto 40px auto;
  background: #fff; border: 1px solid var(--outline); border-radius: 18px; padding: 28px;
  box-shadow: var(--shadow);
}
.formulario h1{ margin: 0 0 8px; font-size: clamp(24px, 4vw, 32px); }
.plan-badge{
  display: inline-flex; align-items: center; gap:10px; margin: 6px 0 12px;
  padding: 6px 10px; background: rgba(255,122,0,.1); border: 1px solid var(--primary); border-radius: 999px; font-size: .95rem;
}

/* Alerts */
.alert{
  border-radius: 10px; padding: 12px 14px; margin: 8px 0 0; font-weight: 500;
  border: 1px solid;
}
.alert-success{ background: #ecfdf5; color: #047857; border-color: #a7f3d0; }
.alert-error{ background: #fff1f2; color: #be123c; border-color: #fecdd3; }

/* Form */
form{ display: flex; flex-direction: column; gap: 12px; margin-top: 12px; }
label{ font-size: .92rem; font-weight: 600; color: #111827; }
.input-field{ position: relative; }
.input-field input{
  width: 100%; padding: 12px 14px; font-size: 1rem; border-radius: 12px; border: 1px solid var(--outline);
  background: #fff; color: var(--text); transition: border-color .2s, box-shadow .2s;
}
.input-field input:focus{ outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(255,122,0,.22); }

/* Icon button (show/hide password) */
.has-icon .icon-btn{
  position: absolute; right: 10px; top: 70%; transform: translateY(-50%);
  background: transparent; border: 0; cursor: pointer; font-size: 1.05rem; color: #6b7280;
}
.has-icon .icon-btn:hover{ color: var(--primary); }

.submit{ margin-top: 6px; }
.btnLogin{
  width: 100%; display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding: 14px; font-weight:700; font-size: 1.05rem; border-radius: 14px; border: none; cursor: pointer;
  background: linear-gradient(180deg, var(--primary), var(--primary-700)); color: #fff; box-shadow: var(--shadow);
  transition: transform .15s ease, filter .15s ease;
}
.btnLogin:hover:not(:disabled){ transform: translateY(-1px); filter: brightness(1.03); }
.btnLogin:disabled{ background: #c8c8c8; cursor: not-allowed; }

.helper{ margin-top: 10px; color: #6b7280;  text-align: center;}

/* Footer + legal modal */
footer{ border-top: 1px solid var(--outline); background:#fff; margin-top: 50px; }
.footer-content{
  width: min(1120px, 92vw); margin: 0 auto; padding: 18px 0;
  display:grid; grid-template-columns: 1.2fr 1fr 1fr; gap:18px; align-items:start;
}
.footer-block h4{ margin: 0 0 8px; font-size: 1rem; }
.footer-block p, .footer-block li, .footer-block a{
  font-size: .95rem; margin: 6px 0; color: var(--primary); list-style: none;
}
.footer-block a:hover{ color: var(--primary); }
.footer-block ul{ padding:0; margin:0; }

.modal-overlay{
  position: fixed; inset:0; background: var(--overlay); display:none; align-items:center; justify-content:center; z-index: 200;
}
.modal-content{
  width: min(720px, 92vw); max-height: 80vh; background: #fff; border: 1px solid var(--outline); border-radius: 16px;
  box-shadow: var(--shadow); padding: 18px 16px; position: relative; overflow: auto;
}
.modal-close{ position:absolute; top:6px; right:10px; background:transparent; border:0; font-size:28px; cursor:pointer; color:#444; }

/* Responsive */
/* ================================
   Mobile & Small Tablets
   ================================ */

/* até 980px — muda o layout para fluxo normal e evita overflow */
@media (max-width: 980px){
  .container{
    width: min(1120px, 94vw);
    min-height: auto;
    display: block;          /* quebra o flex para evitar “apertar” no mobile */
    padding: 16px 0 24px;    /* respiro vertical */
  }

  /* A box deixa de ser absoluta (para permitir rolagem natural) */
  .box{
    position: relative !important;
    top: 0 !important;
    left: 0 !important;
    transform: none !important;
    margin: 20px auto 24px !important;
    padding: 22px;
    width: 100%;
    max-width: 560px;        /* um pouco mais folgado em tablets */
    border-radius: 16px;
  }

  /* Título + badge */
  .formulario h1{
    font-size: clamp(22px, 5vw, 28px);
    line-height: 1.2;
  }
  .plan-badge{
    font-size: .9rem;
    padding: 6px 10px;
  }

  /* Navegação fixa com respiro */
  #nav{
    position: sticky;
    top: 0;
    padding: 10px 16px;
    backdrop-filter: saturate(140%) blur(4px);
  }

  /* Botões maiores para toque */
  .btn,
  .btn-lg,
  .btn-entrar,
  .btnLogin{
    border-radius: 14px;
    padding: 12px 14px;
    font-size: 1rem;
  }
  .btnLogin{
    padding: 14px;
  }

  /* Inputs com alvo de toque confortável e evitando zoom no iOS */
  .input-field input{
    padding: 14px 14px;
    font-size: 16px;       /* >=16px evita zoom automático no iOS */
    border-radius: 12px;
  }
  .has-icon .icon-btn{
    right: 12px;
  }

  .submit{ margin-top: 8px; }
  .helper{ margin-top: 12px; text-align: center; }

  /* Footer em 1 coluna */
  footer{
    margin-top: 28px;
  }
  .footer-content{
    width: 94vw;
    grid-template-columns: 1fr;
    gap: 8px;
    text-align: center;
    padding: 16px 0 20px;
  }
  .footer-block h4{ font-size: 0.98rem; }
  .footer-block p, .footer-block li, .footer-block a{
    font-size: 0.95rem;
  }

  /* Modal melhor encaixado */
  .modal-content{
    width: 92vw;
    max-height: 82vh;
    padding: 16px 14px;
    border-radius: 14px;
  }
  .modal-close{
    top: 6px; right: 8px; font-size: 26px;
  }
}

/* até 720px — afina ainda mais os espaços/escala */
@media (max-width: 720px){
  .box{
    max-width: 520px;
    padding: 20px;
  }
  .btn, .btn-lg, .btnLogin{ font-size: 0.98rem; }
  label{ font-size: .9rem; }
}

/* até 480px — celulares pequenos */
@media (max-width: 480px){
  body.is-landing{
    line-height: 1.6;
    background:
      radial-gradient(600px 360px at 10% -10%, rgba(255,122,0,.06), transparent 50%),
      radial-gradient(520px 320px at 90% -20%, rgba(255,122,0,.05), transparent 55%),
      var(--bg);
  }

  .container{ width: 94vw; }
  .box{
    max-width: 460px;
    margin: 16px auto 20px !important;
    padding: 18px;
    border-radius: 14px;
  }

  .formulario h1{ font-size: clamp(20px, 6vw, 26px); }
  .plan-badge{ font-size: .88rem; padding: 5px 9px; }

  .input-field input{
    padding: 13px 12px;
    font-size: 16px;
  }
  .btnLogin{ padding: 13px; }

  .footer-content{
    width: 94vw;
    gap: 6px;
  }
}

/* Acessibilidade: reduz animações em quem prefere menos movimento */
@media (prefers-reduced-motion: reduce){
  *{
    transition: none !important;
    animation: none !important;
    scroll-behavior: auto !important;
  }
}


/* Neutraliza cor do autofill (Chrome/Edge/Safari) */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px #fff inset !important; /* mantém branco */
  box-shadow: 0 0 0 1000px #fff inset !important;
  -webkit-text-fill-color: var(--text) !important;
  caret-color: var(--text);
  transition: background-color 9999s ease-out, color 9999s ease-out;
}
