/* ============================================================
   inscricao.css — Casa dos Patudos
   Formulário de apoio à comitiva
   Meias-Finais Regionais · Novas 7 Maravilhas de Portugal 2026
   ============================================================ */

/* ------------------------------------------------------------
   SECÇÃO COMITIVA
   ------------------------------------------------------------ */
.comitiva__grid{ display:grid; gap:34px; align-items:start; }

/* Coluna de contexto */
.comitiva__intro p:not(.comitiva__chant){ color:var(--ink); }
.comitiva__chant{
  margin:0 0 22px; padding:18px 20px;
  background:var(--green-deep); border-radius:8px; color:#fff;
  font-family:var(--serif); font-weight:900; line-height:1.1;
  font-size:clamp(1.2rem,3.2vw,1.55rem); letter-spacing:-.01em;
}
.comitiva__chant span{ color:var(--gold-soft); display:block; }

/* Destaque da data do evento */
.comitiva__event{
  display:flex; flex-direction:column; gap:4px;
  margin:0 0 22px; padding:18px 22px;
  background:#fff; border:1px solid var(--green-line);
  border-left:5px solid var(--gold); border-radius:8px;
  box-shadow:0 8px 22px rgba(18,63,32,.06);
}
.comitiva__event-lbl{
  font-family:var(--sans); font-weight:700; text-transform:uppercase;
  letter-spacing:.16em; font-size:.72rem; color:var(--gold);
}
.comitiva__event-date{
  font-family:var(--serif); font-weight:900; color:var(--green-deep);
  font-size:clamp(1.15rem,3vw,1.4rem); line-height:1.15; letter-spacing:-.01em;
}
.comitiva__event-place{
  font-family:var(--sans); font-weight:700; color:var(--ink); font-size:.95rem;
}

.factlist{ list-style:none; margin:24px 0 0; padding:0; display:grid; gap:0; }
.factlist li{
  display:grid; grid-template-columns:auto 1fr; gap:16px; align-items:baseline;
  padding:14px 0; border-top:1px solid var(--green-line);
}
.factlist li:last-child{ border-bottom:1px solid var(--green-line); }
.factlist .factlist__k{
  font-family:var(--serif); font-weight:900; color:var(--green-deep);
  font-size:1.05rem; white-space:nowrap;
}
.factlist .factlist__v{ font-size:.96rem; color:var(--ink); line-height:1.6; }

/* Cartão do formulário */
.formcard{
  background:#fff; border:1px solid #E7E5DC; border-radius:10px;
  padding:28px 22px; box-shadow:0 14px 40px rgba(18,63,32,.08);
}
.formcard__head{ margin:0 0 6px; }

/* Aviso de vagas limitadas (urgência) */
.vagas{
  display:flex; gap:12px; align-items:flex-start; margin:0 0 22px;
  padding:14px 16px; background:#FBEAE7; border:1px solid #EBC4BD;
  border-left:4px solid var(--red); border-radius:8px;
}
.vagas__dot{
  flex:none; width:11px; height:11px; margin-top:5px; border-radius:50%;
  background:var(--red); position:relative;
}
.vagas__dot::after{
  content:""; position:absolute; inset:0; border-radius:50%;
  background:var(--red); animation:vagasPulse 1.9s ease-out infinite;
}
@keyframes vagasPulse{ 0%{ transform:scale(1); opacity:.55; } 100%{ transform:scale(2.8); opacity:0; } }
.vagas__text{ margin:0; font-size:.9rem; line-height:1.5; color:var(--red-deep); }
.vagas__text strong{ display:block; }
.vagas__text b{ color:var(--red-deep); white-space:nowrap; }
@media (prefers-reduced-motion:reduce){ .vagas__dot::after{ animation:none; } }
.formcard__title{ font-family:var(--serif); font-weight:900; color:var(--green-deep); font-size:1.5rem; margin:0 0 6px; line-height:1.1; }
.formcard__lead{ font-size:.95rem; color:var(--ink-soft); margin:0 0 20px; line-height:1.55; }

.field{ margin:0 0 16px; }
.field__row{ display:grid; gap:16px; }
.field label{
  display:block; font-weight:700; font-size:.86rem; color:var(--green-deep);
  margin:0 0 6px; letter-spacing:.01em;
}
.field label .req{ color:var(--red); margin-left:2px; }
.field input{
  width:100%; font-family:var(--sans); font-size:1rem; color:var(--ink);
  background:var(--paper); border:1px solid #D9D7CC; border-radius:6px;
  padding:13px 14px; min-height:50px; transition:border-color .15s, box-shadow .15s;
}
.field input::placeholder{ color:#A7A59B; }
.field input:focus{
  outline:none; border-color:var(--green);
  box-shadow:0 0 0 3px rgba(26,92,46,.16); background:#fff;
}
.field input:user-invalid{ border-color:var(--red); }
.field-hint{ display:block; margin-top:6px; font-size:.78rem; color:#88857B; }

/* Checkbox de políticas */
.consent{
  display:grid; grid-template-columns:auto 1fr; gap:13px; align-items:start;
  margin:4px 0 20px; padding:16px; background:var(--green-tint);
  border:1px solid var(--green-line); border-radius:8px;
}
.consent input[type="checkbox"]{
  appearance:none; -webkit-appearance:none; margin:0; flex:none; cursor:pointer;
  width:26px; height:26px; border:2px solid var(--green); border-radius:6px;
  background:#fff; display:grid; place-content:center; transition:background .15s, border-color .15s;
}
.consent input[type="checkbox"]::after{
  content:""; width:12px; height:7px; margin-top:-3px;
  border-left:3px solid #fff; border-bottom:3px solid #fff;
  transform:rotate(-45deg) scale(0); transform-origin:center; transition:transform .15s;
}
.consent input[type="checkbox"]:checked{ background:var(--green); border-color:var(--green); }
.consent input[type="checkbox"]:checked::after{ transform:rotate(-45deg) scale(1); }
.consent input[type="checkbox"]:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(26,92,46,.25); }
.consent label{ font-size:.88rem; color:var(--ink); line-height:1.55; font-weight:400; margin:0; cursor:pointer; }
.consent label a{ color:var(--green); font-weight:700; }

.formcard .btn--green{ width:100%; }

.form-note{ font-size:.78rem; color:var(--ink-soft); line-height:1.5; margin:14px 0 0; text-align:center; }
.form-note svg{ width:.95em; height:.95em; vertical-align:-2px; color:var(--green); }

/* Mensagens de feedback */
.form-msg{
  display:none; margin:0 0 18px; padding:16px 18px; border-radius:8px;
  font-size:.94rem; line-height:1.55;
}
.form-msg.is-on{ display:block; }
.form-msg--ok{ background:var(--green-tint); border:1px solid var(--green-line); color:var(--green-deep); }
.form-msg--err{ background:#FBEAE7; border:1px solid #EBC4BD; color:var(--red-deep); }
.form-msg strong{ display:block; margin-bottom:3px; }

/* Estado de sucesso (substitui o formulário) */
.formcard__success{ display:none; text-align:center; padding:14px 4px; }
.formcard.is-done .formcard__success{ display:block; }
.formcard.is-done .formcard__body{ display:none; }
.formcard__success .seal{ width:64px; height:64px; margin:0 auto 16px; color:var(--green); }
.formcard__success h3{ color:var(--green-deep); margin:0 0 10px; }
.formcard__success p:not(.comitiva__chant){ color:var(--ink); font-size:.96rem; margin:0 0 .8em; }
.formcard__success .comitiva__chant{ color:#fff; }

/* Honeypot anti-spam — escondido de humanos */
.hp-field{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

@media (min-width:860px){
  .comitiva__grid{ grid-template-columns:1fr 1fr; gap:48px; }
  .formcard{ padding:36px 32px; }
  .field__row{ grid-template-columns:1fr 1fr; }
}
