/* ============================================================
   Layout da página de Contato (compartilhado entre
   contato.php e contato-ok.php para manter visual idêntico)
   ============================================================ */

/* ---- Contact-specific ---- */
.contact-hero {
  position: relative;
  background:
    radial-gradient(circle at 50% 40%, rgba(28,28,30,0.75), rgba(0,0,0,0.92)),
    radial-gradient(circle at 12px 12px, rgba(255,255,255,0.04) 2px, transparent 3px) 0 0/30px 30px,
    #050505;
  padding: clamp(56px, 8vw, 96px) 0;
  text-align: center;
  border-bottom: 1px solid var(--line);
}
.contact-hero h1 { font-family: var(--font-techno); font-weight: 600; font-size: clamp(30px, 4.4vw, 52px); letter-spacing: 0.12em; text-transform: uppercase; color: #fff; margin: 0; }
.contact-hero p { color: var(--t-2); max-width: 64ch; margin: 18px auto 0; font-size: 15px; }
.contact-hero p.kc { margin-top: 14px; }
.contact-hero p.kc strong { color: #fff; }
.contact-hero .btn-buy { margin-top: 26px; padding: 14px 34px; font-size: 12px; }

.contact-body {
  background:
    radial-gradient(circle at 18% 8%, rgba(200, 11, 15, 0.08), transparent 28%),
    linear-gradient(180deg, #f7f7f8 0%, #ececef 100%);
  color: #1a1a1d;
  padding: clamp(48px, 7vw, 88px) 0;
}
.contact-body .block + .block { margin-top: clamp(40px, 6vw, 72px); }
.contact-body h2 { font-family: var(--font-ui); font-weight: 700; font-size: clamp(20px, 2.4vw, 26px); letter-spacing: 0.06em; text-transform: uppercase; color: #111; margin: 0 0 18px; }
.contact-shell {
  display: grid;
  grid-template-columns: minmax(250px, 0.72fr) minmax(0, 1.7fr);
  gap: clamp(24px, 4vw, 42px);
  align-items: start;
}
.contact-methods { display: grid; gap: 16px; }
.contact-card {
  position: relative;
  overflow: hidden;
  min-height: 156px;
  padding: 24px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.08), transparent 42%),
    linear-gradient(180deg, #17171a, #080809);
  border: 1px solid rgba(255,255,255,0.12);
  color: #fff;
  box-shadow: 0 22px 44px rgba(10, 10, 12, 0.16);
  transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
.contact-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--red-bright);
}
.contact-card::after {
  content: "";
  position: absolute;
  right: -38px;
  top: -38px;
  width: 118px;
  height: 118px;
  border: 1px solid rgba(224, 18, 24, 0.28);
  transform: rotate(28deg);
}
.contact-card__icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  margin-bottom: 22px;
  color: #fff;
  background: rgba(224, 18, 24, 0.18);
  border: 1px solid rgba(224, 18, 24, 0.45);
}
.contact-card__icon svg { width: 24px; height: 24px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.contact-card > span:not(.contact-card__icon) {
  display: block;
  color: rgba(255,255,255,0.58);
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.contact-card strong {
  display: block;
  margin-top: 8px;
  font-family: var(--font-ui);
  font-size: clamp(20px, 2vw, 25px);
  letter-spacing: 0.03em;
}
.contact-card a { color: inherit; text-decoration: none; }
.contact-card:hover { transform: translateY(-2px); box-shadow: 0 28px 54px rgba(10, 10, 12, 0.22); }
.contact-form-card {
  position: relative;
  overflow: hidden;
  background: #fff;
  border: 1px solid #dedee2;
  box-shadow: 0 28px 70px rgba(18, 18, 22, 0.12);
  padding: clamp(24px, 4vw, 42px);
}
.contact-form-card::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--red-bright), rgba(224, 18, 24, 0));
}
.contact-form-head {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: flex-start;
  margin-bottom: 24px;
}
.contact-form-head h3 {
  margin: 0;
  color: #111;
  font-family: var(--font-ui);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}
.contact-form-head p {
  max-width: 42ch;
  margin: 8px 0 0;
  color: #5f6168;
  font-size: 14px;
  line-height: 1.65;
}

.accordion { border: 1px solid #d8d8da; background: #fff; }
.accordion + .accordion { border-top: none; }
.accordion > summary {
  list-style: none; cursor: pointer; padding: 16px 20px;
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-ui); font-weight: 700; font-size: 14px; letter-spacing: 0.08em; text-transform: uppercase; color: #1a1a1d;
  background: #efeff0;
}
.accordion > summary::-webkit-details-marker { display: none; }
.accordion > summary::before { content: "▶"; font-size: 9px; color: #c80b0f; transition: transform .2s var(--ease); }
.accordion[open] > summary::before { transform: rotate(90deg); }
.accordion__inner { padding: clamp(22px, 3vw, 34px); }
.accordion__intro { font-size: 14px; color: #444; margin: 0 0 22px; }
.accordion__intro b { color: var(--red); }

.req-note { font-size: 12px; color: #777; margin: 0 0 18px; }
.req-note b { color: var(--red); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field.full { grid-column: 1 / -1; }
.field > label { font-family: var(--font-ui); font-weight: 800; font-size: 12px; color: #1a1a1d; letter-spacing: 0.08em; text-transform: uppercase; }
.field > label .req { color: var(--red); }
.field .sub { font-size: 11px; color: #888; margin-top: -2px; }
.field input, .field textarea {
  background: #f7f7f8; border: 1px solid #d4d4d8; padding: 14px 15px;
  font-family: var(--font-ui); font-size: 14px; color: #111; width: 100%;
  transition: border-color .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease);
}
.field input::placeholder, .field textarea::placeholder { color: #8d8f96; }
.field input:focus, .field textarea:focus { outline: none; background: #fff; border-color: var(--red); box-shadow: 0 0 0 3px rgba(224, 18, 24, 0.12); }
.field textarea { resize: vertical; min-height: 172px; line-height: 1.65; }
.sub-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 20px; }
.charcount { font-size: 12px; color: #888; margin: 8px 0 0; }
.form-submit {
  margin-top: 24px; background: var(--red-bright); color: #fff; border: none;
  padding: 15px 42px; font-family: var(--font-ui); font-weight: 800; font-size: 13px;
  letter-spacing: 0.18em; text-transform: uppercase; cursor: pointer; transition: background .18s var(--ease), transform .18s var(--ease);
}
.form-submit:hover { background: var(--red); transform: translateY(-1px); }

.owners {
  position: relative; text-align: center;
  background:
    linear-gradient(rgba(0,0,0,0.78), rgba(0,0,0,0.78)),
    radial-gradient(circle at 12px 12px, rgba(255,255,255,0.04) 2px, transparent 3px) 0 0/30px 30px,
    #050505;
  padding: clamp(56px, 8vw, 96px) 0;
}
.owners h2 { font-family: var(--font-techno); font-weight: 600; font-size: clamp(28px, 4vw, 46px); letter-spacing: 0.1em; text-transform: uppercase; color: #fff; margin: 0; }
.owners p { color: var(--t-2); max-width: 70ch; margin: 18px auto 0; font-size: 15px; }
.owners p b { color: #fff; }
.owners .btn-buy { margin-top: 26px; padding: 14px 34px; font-size: 12px; }
.contact-alert {
  margin: 0 0 22px;
  padding: 18px 20px;
  border: 1px solid rgba(224, 18, 24, 0.28);
  background: rgba(224, 18, 24, 0.08);
  color: #1a1a1d;
  font-family: var(--font-ui);
  line-height: 1.6;
}
.contact-alert strong { display: block; font-size: 16px; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 4px; }
.contact-alert--error {
  border-color: rgba(200, 11, 15, 0.32);
  background: rgba(200, 11, 15, 0.12);
}
.success-panel {
  min-height: 430px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: clamp(34px, 5vw, 58px);
  color: #fff;
  background:
    radial-gradient(circle at 50% 20%, rgba(224, 18, 24, 0.22), transparent 34%),
    linear-gradient(145deg, #17171a, #050505);
  border: 1px solid rgba(255,255,255,0.12);
}
.success-panel__mark {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  margin: 0 auto 24px;
  color: #fff;
  background: var(--red-bright);
  box-shadow: 0 18px 38px rgba(224, 18, 24, 0.28);
}
.success-panel__mark svg { width: 34px; height: 34px; stroke: currentColor; fill: none; stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }
.success-panel h3 {
  max-width: 620px;
  margin: 0 auto 14px;
  font-family: var(--font-ui);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.18;
  text-transform: uppercase;
}
.success-panel p {
  max-width: 54ch;
  margin: 0 auto;
  color: rgba(255,255,255,0.74);
  font-size: 15px;
  line-height: 1.75;
}
.success-panel .btn-buy { margin-top: 30px; padding: 14px 40px; font-size: 12px; }

@media (max-width: 860px) {
  .contact-shell { grid-template-columns: 1fr; }
  .contact-methods { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 720px) {
  .form-grid { grid-template-columns: 1fr; }
  .sub-2 { grid-template-columns: 1fr; }
  .contact-methods { grid-template-columns: 1fr; }
  .contact-form-head { display: block; }
  .form-submit { width: 100%; }
}
