/* ============================================================
   PUPA — páginas de formulário (Trabalhe Conosco / Solicitar Proposta)
   depende de styles.css
   ============================================================ */

/* Subpage hero */
.subhero{ padding-top:128px; padding-bottom:clamp(40px,5vw,64px); position:relative; overflow:hidden; }
.subhero .wrap{ position:relative; z-index:1; }

/* ============================================================
   Documento jurídico (Política de Privacidade / LGPD)
   ============================================================ */
.legal-layout{ display:grid; grid-template-columns:248px 1fr; gap:clamp(32px,5vw,72px); align-items:start; }
.legal-toc{ position:sticky; top:96px; align-self:start; }
.legal-toc__title{ font-family:var(--body); font-weight:600; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); margin-bottom:16px; }
.legal-toc ol{ list-style:none; margin:0; padding:0; counter-reset:toc; display:grid; gap:2px; }
.legal-toc li{ counter-increment:toc; }
.legal-toc a{ display:flex; gap:11px; padding:8px 12px; border-radius:10px; font-size:13.5px; font-weight:500; color:var(--muted); line-height:1.35; transition:background .2s, color .2s; }
.legal-toc a::before{ content:counter(toc,decimal-leading-zero); font-family:var(--display); font-weight:600; font-size:11.5px; color:var(--green-deep); flex:none; padding-top:1px; }
.legal-toc a:hover{ background:var(--green-tint); color:var(--ink); }

.legal-meta{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:34px; }
.legal-meta .pill{ display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600; color:var(--ink-soft); background:#fff; border:1px solid var(--line); border-radius:999px; padding:8px 15px; }
.legal-meta .pill svg{ width:14px; height:14px; color:var(--green-deep); flex:none; }

.legal-doc{ max-width:760px; }
.legal-doc section{ scroll-margin-top:96px; padding-block:clamp(26px,3vw,38px); border-top:1px solid var(--line); }
.legal-doc section:first-of-type{ border-top:none; padding-top:0; }
.legal-doc h2{ font-size:clamp(21px,2.4vw,27px); display:flex; align-items:baseline; gap:14px; }
.legal-doc h2 .sn{ font-family:var(--display); font-weight:600; font-size:15px; color:var(--green-deep); flex:none; }
.legal-doc h3{ font-size:17px; margin-top:24px; }
.legal-doc p{ margin-top:15px; color:var(--muted); font-size:15.5px; line-height:1.72; text-wrap:pretty; }
.legal-doc p.lead{ color:var(--ink-soft); font-size:16.5px; }
.legal-doc strong{ color:var(--ink-soft); font-weight:600; }
.legal-doc a{ color:var(--green-deep); font-weight:600; text-decoration:underline; text-underline-offset:2px; text-decoration-thickness:1px; }
.legal-doc ul{ margin:15px 0 0; padding:0; list-style:none; display:grid; gap:11px; }
.legal-doc ul li{ position:relative; padding-left:28px; color:var(--muted); font-size:15.5px; line-height:1.6; }
.legal-doc ul li::before{ content:""; position:absolute; left:6px; top:9px; width:7px; height:7px; border-radius:2px; background:var(--green); }
.legal-doc ul.rights li{ padding-left:0; }
.legal-doc ul.rights li::before{ display:none; }
.legal-doc ul.rights li{ display:flex; gap:13px; align-items:flex-start; padding:15px 18px; background:var(--bg-2); border:1px solid var(--line-2); border-radius:var(--r); }
.legal-doc ul.rights li svg{ width:19px; height:19px; color:var(--green-deep); flex:none; margin-top:2px; }
.legal-doc ul.rights b{ font-family:var(--display); font-weight:600; color:var(--ink); font-size:15px; display:block; margin-bottom:3px; }

.legal-callout{ margin-top:24px; background:var(--green-tint-2); border:1px solid var(--green-tint); border-radius:var(--r-lg); padding:clamp(22px,3vw,32px); display:flex; gap:18px; align-items:flex-start; }
.legal-callout svg{ width:26px; height:26px; color:var(--green-deep); flex:none; margin-top:2px; }
.legal-callout h3{ margin-top:0; font-size:18px; }
.legal-callout p{ margin-top:8px; }
.legal-callout .ct-mail{ margin-top:14px; display:inline-flex; align-items:center; gap:9px; font-weight:600; color:var(--green-deep); font-size:15px; }

@media (max-width:900px){
  .legal-layout{ grid-template-columns:1fr; }
  .legal-toc{ position:static; display:none; }
}
.subhero .back{ display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:600; color:var(--muted); margin-bottom:22px; transition:color .2s; }
.subhero .back:hover{ color:var(--green-deep); }
.subhero .back svg{ width:16px; height:16px; }
.subhero h1{ font-size:clamp(32px,4.6vw,54px); max-width:18ch; margin-top:10px; }
.subhero h1 .accent{ color:var(--green); }
.subhero p{ margin-top:20px; font-size:clamp(16px,1.7vw,19px); color:var(--muted); max-width:54ch; text-wrap:pretty; }

/* Layout form + aside */
.form-layout{ display:grid; grid-template-columns:1.35fr .65fr; gap:clamp(28px,4vw,56px); align-items:start; padding-bottom:var(--sec-y); }
.form-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(26px,3.4vw,46px); box-shadow:var(--shadow); }

/* Fieldset / groups */
.fset{ border:none; padding:0; margin:0 0 8px; }
.fset + .fset{ margin-top:34px; padding-top:30px; border-top:1px solid var(--line-2); }
.fset__legend{ display:flex; align-items:center; gap:11px; font-family:var(--display); font-weight:600; font-size:16.5px; letter-spacing:-.01em; margin-bottom:22px; }
.fset__legend .n{ width:26px; height:26px; border-radius:8px; background:var(--green-tint); color:var(--green-deep); display:grid; place-items:center; font-family:var(--body); font-size:13px; font-weight:700; flex:none; }

/* Grid of fields */
.fgrid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field.col-2{ grid-column:span 2; }
.field label{ font-size:13.5px; font-weight:600; color:var(--ink-soft); }
.field label .req{ color:var(--green-deep); margin-left:2px; }
.field .hint{ font-size:12px; color:var(--muted-2); font-weight:400; }

.input, .select, .textarea{
  width:100%; font-family:var(--body); font-size:15px; color:var(--ink);
  background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-sm);
  padding:13px 14px; transition:border-color .2s, background .2s, box-shadow .2s; appearance:none;
}
.input::placeholder, .textarea::placeholder{ color:var(--muted-2); }
.input:focus, .select:focus, .textarea:focus{ outline:none; border-color:var(--green); background:#fff; box-shadow:0 0 0 4px rgba(0,180,90,.12); }
.textarea{ resize:vertical; min-height:120px; line-height:1.6; }
.select{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 13px center; padding-right:40px; cursor:pointer; }
.input.invalid, .select.invalid, .textarea.invalid{ border-color:#dc2626; background:#fff5f5; }
.field .err{ font-size:12px; color:#dc2626; font-weight:500; display:none; }
.field.show-err .err{ display:block; }

/* File upload */
.filedrop{ border:1.5px dashed var(--line); border-radius:var(--r-sm); padding:22px; text-align:center; background:var(--bg-2); cursor:pointer; transition:border-color .2s, background .2s; }
.filedrop:hover, .filedrop.drag{ border-color:var(--green); background:var(--green-tint-2); }
.filedrop input{ display:none; }
.filedrop .ic{ width:42px; height:42px; border-radius:11px; background:var(--green-tint); color:var(--green-deep); display:grid; place-items:center; margin:0 auto 12px; }
.filedrop .ic svg{ width:20px; height:20px; }
.filedrop .ft{ font-size:14px; font-weight:600; color:var(--ink); }
.filedrop .ft b{ color:var(--green-deep); }
.filedrop .fs{ font-size:12px; color:var(--muted-2); margin-top:4px; }
.filedrop.has-file{ border-style:solid; border-color:var(--green); background:var(--green-tint-2); }
.filedrop .picked{ display:none; align-items:center; gap:9px; justify-content:center; font-size:13.5px; font-weight:600; color:var(--green-deep); }
.filedrop.has-file .picked{ display:flex; }
.filedrop.has-file .prompt{ display:none; }

/* Segmented radio (sim/não) */
.seg{ display:inline-flex; background:var(--bg-2); border:1px solid var(--line); border-radius:999px; padding:4px; gap:4px; }
.seg label{ position:relative; }
.seg input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.seg span{ display:inline-flex; align-items:center; justify-content:center; padding:8px 20px; border-radius:999px; font-size:14px; font-weight:600; color:var(--muted); transition:.2s; cursor:pointer; }
.seg input:checked + span{ background:var(--green); color:#fff; }

/* Checkboxes (consent) */
.checks{ display:grid; gap:14px; margin-top:8px; }
.check{ display:flex; gap:12px; align-items:flex-start; cursor:pointer; }
.check input{ appearance:none; width:21px; height:21px; flex:none; margin-top:1px; border:1.5px solid var(--line); border-radius:6px; background:#fff; cursor:pointer; transition:.2s; position:relative; }
.check input:checked{ background:var(--green); border-color:var(--green); }
.check input:checked::after{ content:""; position:absolute; left:6px; top:2.5px; width:6px; height:11px; border:solid #fff; border-width:0 2.5px 2.5px 0; transform:rotate(45deg); }
.check span{ font-size:13.5px; color:var(--muted); line-height:1.5; }
.check span a{ color:var(--green-deep); font-weight:600; text-decoration:underline; }
.check.show-err input{ border-color:#dc2626; }

/* Submit */
.form-actions{ margin-top:30px; display:flex; flex-direction:column; gap:14px; }
.form-actions .btn{ width:100%; }
.form-note{ font-size:12.5px; color:var(--muted-2); display:flex; align-items:center; gap:8px; justify-content:center; }
.form-note svg{ width:14px; height:14px; color:var(--green-deep); flex:none; }

/* Aside */
.aside{ position:sticky; top:96px; display:grid; gap:16px; }
.aside__card{ border:1px solid var(--line); border-radius:var(--r-lg); padding:28px; background:#fff; }
.aside__card.dark{ background:var(--dark); color:var(--on-dark); border-color:transparent; }
.aside__card h3{ font-size:18px; }
.aside__card.dark h3{ color:#fff; }
.aside__list{ display:grid; gap:16px; margin-top:18px; }
.aside__list li{ display:flex; gap:13px; align-items:flex-start; font-size:14px; color:var(--muted); line-height:1.5; }
.aside__card.dark .aside__list li{ color:var(--on-dark-muted); }
.aside__list .ai{ width:32px; height:32px; border-radius:9px; flex:none; display:grid; place-items:center; background:var(--green-tint); color:var(--green-deep); }
.aside__card.dark .aside__list .ai{ background:rgba(255,255,255,.08); color:var(--green); }
.aside__list .ai svg{ width:16px; height:16px; }
.aside__list b{ display:block; color:var(--ink); font-weight:600; font-size:14.5px; margin-bottom:2px; }
.aside__card.dark .aside__list b{ color:#fff; }
.aside__contact{ display:grid; gap:14px; margin-top:6px; }
.aside__contact a{ display:flex; gap:11px; align-items:center; font-size:14.5px; font-weight:600; color:var(--ink); }
.aside__card.dark .aside__contact a{ color:#fff; }
.aside__contact a svg{ width:17px; height:17px; color:var(--green); flex:none; }

/* Success overlay */
.success{ position:fixed; inset:0; z-index:90; background:rgba(5,5,5,.55); backdrop-filter:blur(6px); display:none; place-items:center; padding:24px; }
.success.show{ display:grid; animation:fadeIn .3s var(--ease); }
@keyframes fadeIn{ from{opacity:0} to{opacity:1} }
.success__card{ background:#fff; border-radius:var(--r-xl); padding:clamp(34px,5vw,56px); max-width:480px; text-align:center; box-shadow:var(--shadow-lg); animation:popIn .4s var(--ease); }
@keyframes popIn{ from{ transform:scale(.92) translateY(12px); opacity:0 } to{ transform:none; opacity:1 } }
.success__ic{ width:74px; height:74px; border-radius:50%; background:var(--green-tint); color:var(--green-deep); display:grid; place-items:center; margin:0 auto 24px; }
.success__ic svg{ width:36px; height:36px; }
.success__card h2{ font-size:26px; }
.success__card p{ margin-top:14px; color:var(--muted); font-size:15.5px; line-height:1.6; }
.success__card .btn{ margin-top:28px; }

@media (max-width:900px){
  .form-layout{ grid-template-columns:1fr; }
  .aside{ position:static; }
}
@media (max-width:560px){
  .fgrid{ grid-template-columns:1fr; }
  .field.col-2{ grid-column:span 1; }
}
