/*
 * Inauguração Nali — Cadastro
 * Design: Liquid Glass card sobre fundo creme, com countdown
 * Paleta: marrom Nali #673421 + creme #F4F0E6 + accent verde #9B9855
 */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#F4F0E6;
  --bg-2:#D8CFC4;
  --ink:#673421;
  --ink-soft:#9C8F83;
  --accent:#9B9855;
  --accent-deep:#5E5530;
  --line:rgba(103,52,33,.16);
  --line-strong:rgba(103,52,33,.36);
  --display:'Open Sans', sans-serif;
  --body:'Open Sans', ui-sans-serif, system-ui, sans-serif;
}

html,body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  overflow-x:hidden;
}

body{
  max-width:520px;margin:0 auto;
  background:var(--bg);
  position:relative;
}

/* Pattern de pontos sutis no fundo */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(rgba(103,52,33,.05) 1px, transparent 1px);
  background-size:3px 3px;opacity:.55;mix-blend-mode:multiply;
}

main{position:relative;z-index:1}

/* ── Top brand row ─────────────────────────────── */
.topbar{
  display:flex;align-items:center;justify-content:center;
  padding:24px 20px 16px;
  position:relative;
}
.topbar .logo{
  height:64px;width:auto;display:block;
}
.topbar .city{
  position:absolute;right:20px;top:50%;transform:translateY(-50%);
  font-size:9px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;
}

/* ── Hero copy ─────────────────────────────────── */
.hero{
  padding:32px 24px 20px;
  text-align:center;
}
.hero .eyebrow{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent);font-weight:600;
  margin-bottom:18px;
  display:inline-flex;align-items:center;gap:10px;
}
.hero .eyebrow::before, .hero .eyebrow::after{
  content:"";display:block;width:24px;height:1px;background:var(--accent);opacity:.6;
}
.hero h1{
  font-family:var(--display);
  font-weight:400;font-size:44px;line-height:1;
  letter-spacing:-.01em;
  margin-bottom:18px;
}
.hero h1 em{font-style:italic;color:var(--accent-deep)}
.hero p{
  font-size:14px;line-height:1.6;color:var(--ink);opacity:.85;
  max-width:34ch;margin:0 auto;
}

/* ── Date + Countdown ──────────────────────────── */
.date-block{
  padding:8px 24px 24px;
  display:flex;flex-direction:column;align-items:center;gap:18px;
}
.date-card{
  display:inline-flex;flex-direction:column;align-items:center;gap:4px;
  padding:12px 22px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:3px;
}
.date-card .d{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink);font-weight:600;
}
.countdown{display:flex;gap:10px;width:100%;max-width:340px}
.cd-cell{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;
}
.cd-num{
  font-family:var(--display);
  font-size:38px;line-height:1;font-weight:400;
  color:var(--ink);font-variant-numeric:tabular-nums;
  padding-bottom:6px;
  border-bottom:1px solid var(--line-strong);
  width:100%;text-align:center;
}
.cd-lbl{
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:500;
}

/* ── Form section ──────────────────────────────── */
.form-section{
  padding:28px 24px 36px;
  background:var(--bg);
  position:relative;
}

/* Liquid Glass card · tint verde Nali (accent) */
.glass{
  position:relative;
  border-radius:28px;
  padding:32px 22px 26px;
  background:
    linear-gradient(135deg,
      rgba(155,152,85,.92) 0%,
      rgba(132,128,68,.94) 50%,
      rgba(94,85,48,.96) 100%);
  backdrop-filter:blur(28px) saturate(180%) brightness(1.05);
  -webkit-backdrop-filter:blur(28px) saturate(180%) brightness(1.05);
  border:1px solid rgba(255,255,255,.35);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.45),
    inset 1px 0 0 rgba(255,255,255,.18),
    inset 0 -1px 0 rgba(0,0,0,.10),
    0 1px 1px rgba(94,85,48,.10),
    0 12px 30px -10px rgba(94,85,48,.32),
    0 30px 60px -20px rgba(94,85,48,.45);
  isolation:isolate;
  overflow:hidden;
}
.glass::before{
  content:"";position:absolute;left:14%;right:14%;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.85), transparent);
  pointer-events:none;
}
.glass::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 40% at 20% 0%, rgba(255,255,255,.16) 0%, transparent 60%);
  mix-blend-mode:overlay;
}

.form-head{text-align:center;margin-bottom:22px;color:#fff}
.form-head .logo-inverted{
  height:36px;width:auto;margin-bottom:10px;
  filter:brightness(0) invert(1);opacity:.95;
}
.form-head h2{
  font-family:var(--display);font-weight:400;
  font-size:26px;line-height:1.1;letter-spacing:-.005em;
  color:#fff;margin-bottom:6px;
  text-shadow:0 1px 2px rgba(0,0,0,.12);
}
.form-head p{
  font-size:12px;line-height:1.5;color:rgba(255,255,255,.88);
  max-width:30ch;margin:0 auto;
}

form{display:flex;flex-direction:column;gap:14px;position:relative;z-index:1}

.field{display:flex;flex-direction:column;gap:6px}
.field label{
  font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:#fff;font-weight:600;
  display:flex;justify-content:space-between;
}
.field label .req{color:rgba(255,255,255,.85);font-weight:400;letter-spacing:0}
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"]{
  appearance:none;outline:0;
  background:#FFFFFF;
  border:1px solid rgba(0,0,0,.08);
  border-radius:12px;
  padding:13px 14px;
  font:500 15px/1.3 var(--body);
  color:var(--ink);
  width:100%;
  box-shadow:0 1px 2px rgba(0,0,0,.05);
  transition:border-color .2s, box-shadow .2s;
}
.field input::placeholder{color:rgba(31,23,20,.35)}
.field input:focus{
  border-color:rgba(255,255,255,.9);
  box-shadow:0 0 0 3px rgba(255,255,255,.45), 0 2px 8px rgba(0,0,0,.08);
}
.field.err input{
  border-color:rgba(255,255,255,.95);
  box-shadow:0 0 0 3px rgba(255,255,255,.5);
}
.field .msg{
  font-size:10.5px;color:#fff;min-height:13px;
  font-style:italic;letter-spacing:.02em;opacity:.95;
}

/* HONEYPOT: invisível para humanos, presente para bots */
.hp{
  position:absolute !important;
  left:-9999px !important;
  width:1px;height:1px;
  overflow:hidden;
}

/* Consent LGPD checkbox */
.field.consent{
  margin-top:6px;
}
.consent-label{
  display:flex !important;
  align-items:flex-start;
  gap:10px;
  cursor:pointer;
  font-size:11px !important;
  line-height:1.5;
  letter-spacing:0 !important;
  text-transform:none !important;
  font-weight:400 !important;
  color:rgba(255,255,255,.9);
  justify-content:flex-start !important;
}
.consent-label input[type="checkbox"]{
  margin-top:2px;
  width:14px;height:14px;
  accent-color:#fff;
  flex:0 0 auto;
  cursor:pointer;
}
.consent-label a{
  color:#fff;
  text-decoration:underline;
  text-underline-offset:2px;
}
.consent-label span{
  flex:1;
}
.field.consent.err{
  /* Estilo de erro para o checkbox: borda sutil em vermelho-pálido no wrapper */
}
.field.consent.err .consent-label span{
  color:#FFE0E0;
}

button.submit{
  appearance:none;border:0;cursor:pointer;font:inherit;
  background:#FFFFFF;color:var(--accent-deep);
  padding:16px 22px;
  font-weight:700;font-size:11px;letter-spacing:.3em;
  text-transform:uppercase;
  border-radius:14px;
  margin-top:8px;
  display:inline-flex;align-items:center;justify-content:center;gap:14px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 1px 2px rgba(0,0,0,.06),
    0 8px 20px -6px rgba(0,0,0,.25);
  transition:transform .15s, box-shadow .2s, background .2s;
}
button.submit:hover:not([disabled]){
  background:var(--bg);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,1),
    0 1px 2px rgba(0,0,0,.05),
    0 12px 28px -6px rgba(0,0,0,.32);
}
button.submit:active{transform:translateY(1px)}
button.submit[disabled]{opacity:.55;cursor:not-allowed}
button.submit .arrow{display:inline-block;transition:transform .25s}
button.submit:hover:not([disabled]) .arrow{transform:translateX(4px)}
button.submit .spin{
  width:13px;height:13px;border-radius:50%;
  border:1.5px solid rgba(94,85,48,.25);
  border-top-color:var(--accent-deep);
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.legal{
  margin-top:14px;
  font-size:10.5px;line-height:1.5;color:rgba(255,255,255,.78);
  text-align:center;
}
.legal a{color:#fff;text-decoration:underline;text-underline-offset:3px}

/* ── Success state ─────────────────────────────── */
.success{text-align:center;color:#fff;animation:fadeUp .6s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:none}}
.success .seal{
  width:64px;height:64px;border-radius:50%;
  border:1px solid rgba(255,255,255,.85);
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:18px;color:#fff;
  font-family:var(--display);font-style:italic;font-size:26px;
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.success h2{
  font-family:var(--display);font-weight:400;font-size:30px;line-height:1.05;
  margin-bottom:12px;letter-spacing:-.01em;color:#fff;
}
.success h2 em{font-style:italic;color:#fff}
.success p{font-size:13px;line-height:1.55;color:rgba(255,255,255,.9);max-width:30ch;margin:0 auto 10px}
.success .next{
  margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,.25);
  display:flex;flex-direction:column;gap:8px;
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.8);
}
.success .next .pair{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.success .next .pair strong{
  color:#fff;font-weight:600;letter-spacing:0;text-transform:none;font-size:12.5px;
}
.success .reset{
  margin-top:18px;background:none;border:0;cursor:pointer;
  font:600 9.5px/1 var(--body);letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.8);
  text-decoration:underline;text-underline-offset:4px;
}
.success .reset:hover{color:#fff}

/* ── Footer ────────────────────────────────────── */
.footer{
  padding:24px;
  text-align:center;
  font-size:11px;line-height:1.6;color:var(--ink);
}
.footer .social{
  margin-top:8px;
  display:flex;align-items:center;justify-content:center;gap:18px;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;
}
.footer .social a{
  color:var(--ink-soft);text-decoration:none;
  padding:6px 0;border-bottom:1px solid transparent;
  display:inline-flex;align-items:center;gap:8px;
  transition:color .2s, border-color .2s;
}
.footer .social a svg{flex:0 0 auto}
.footer .social a:hover{color:var(--ink);border-color:var(--ink-soft)}
.footer .sep{width:1px;height:10px;background:var(--line-strong)}
