/* contact.css — Deviz Zugrav v4.4.0 */

.s-contact { padding: 72px 40px; }

.contact-grid { display: grid; grid-template-columns: 1fr 380px; gap: 56px; align-items: start; }

/* ============================================================
   FORMULAR
   ============================================================ */
.contact-form-wrap h2 { font-size: clamp(20px, 2.2vw, 28px); font-weight: 800; color: var(--dk); margin-bottom: 10px; }
.contact-form-wrap > p { font-size: 15px; color: var(--g5); line-height: 1.7; margin-bottom: 28px; }

.form-alert { display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-radius: 8px; font-size: 14px; font-weight: 600; margin-bottom: 20px; }
.form-alert--success { background: var(--gr1); color: var(--gr6); border: 1px solid #bbf7d0; }
.form-alert--error { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }

.contact-form { display: flex; flex-direction: column; gap: 20px; position: relative; }

.form-row { display: grid; gap: 20px; }
.form-row--2 { grid-template-columns: 1fr 1fr; }

.form-field { display: flex; flex-direction: column; gap: 6px; }

.form-field label { font-size: 13px; font-weight: 700; color: var(--dk); }
.req { color: var(--o6); }

.form-field input[type="text"],
.form-field input[type="email"],
.form-field select,
.form-field textarea {
  width: 100%;
  padding: 12px 14px;
  font-size: 15px;
  font-family: var(--f);
  color: var(--dk);
  background: var(--w);
  border: 1.5px solid var(--g2);
  border-radius: var(--r);
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
  appearance: none;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color: var(--b5);
  box-shadow: 0 0 0 3px rgba(33,150,243,.12);
}

.form-field input.error,
.form-field select.error,
.form-field textarea.error {
  border-color: #dc2626;
  box-shadow: 0 0 0 3px rgba(220,38,38,.08);
}

.form-field select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 40px; cursor: pointer; }

.form-field textarea { resize: vertical; min-height: 140px; }

.char-count { font-size: 12px; color: var(--g5); text-align: right; margin-top: 4px; }

/* GDPR Checkbox */
.form-field--gdpr { margin-top: -4px; }

.checkbox-label { display: flex; align-items: flex-start; gap: 12px; cursor: pointer; font-size: 13px; color: var(--g7); line-height: 1.55; }
.checkbox-label input[type="checkbox"] { position: absolute; opacity: 0; width: 0; height: 0; }
.checkbox-box { width: 18px; height: 18px; min-width: 18px; border: 1.5px solid var(--g2); border-radius: 4px; background: var(--w); display: flex; align-items: center; justify-content: center; transition: background .15s ease, border-color .15s ease; margin-top: 1px; }
.checkbox-label input:checked + .checkbox-box { background: var(--b5); border-color: var(--b5); }
.checkbox-label input:checked + .checkbox-box::after { content: ''; display: block; width: 10px; height: 7px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg) translate(1px, -1px); }
.checkbox-label a { color: var(--b7); text-decoration: underline; }

/* Submit button */
.form-submit-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; width: 100%; font-size: 16px; padding: 16px; cursor: pointer; border: none; }
.form-submit-btn:disabled { opacity: .65; cursor: not-allowed; }

@keyframes spin { to { transform: rotate(360deg); } }
.spin { animation: spin .8s linear infinite; }

/* ============================================================
   INFO CONTACT
   ============================================================ */
.contact-info h2 { font-size: clamp(18px, 2vw, 24px); font-weight: 800; color: var(--dk); margin-bottom: 24px; }

.contact-info-items { display: flex; flex-direction: column; gap: 20px; margin-bottom: 28px; }

.ci-item { display: flex; align-items: flex-start; gap: 14px; }
.ci-icon { width: 40px; height: 40px; border-radius: 8px; background: var(--b1); color: var(--b7); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ci-label { font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--g5); margin-bottom: 3px; }
.ci-value { font-size: 15px; font-weight: 600; color: var(--dk); text-decoration: none; display: block; }
a.ci-value:hover { color: var(--b7); }
.ci-sub { font-size: 13px; color: var(--g5); margin-top: 2px; }

.contact-faq-box, .contact-app-box { background: var(--g0); border: 1px solid var(--g2); border-radius: 10px; padding: 20px; margin-bottom: 12px; }
.contact-faq-box h3, .contact-app-box h3 { font-size: 14px; font-weight: 700; color: var(--dk); margin-bottom: 8px; }
.contact-faq-box p, .contact-app-box p { font-size: 13px; color: var(--g5); line-height: 1.6; margin-bottom: 14px; }

.contact-faq-link, .contact-app-link { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 700; color: var(--b7); text-decoration: none; transition: gap .15s ease; }
.contact-faq-link:hover, .contact-app-link:hover { gap: 10px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .contact-info { max-width: 520px; }
}

@media (max-width: 767px) {
  .s-contact { padding: 48px 20px; }
  .form-row--2 { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .form-field input, .form-field select, .form-field textarea, .checkbox-box { transition: none; }
  .spin { animation: none; }
}

/* CAPTCHA matematic vizibil */
.form-field--captcha label { font-size: 13px; font-weight: 700; color: var(--dk); }
.form-field--captcha label strong {
  display: inline-block;
  background: var(--b1);
  color: var(--b9);
  font-size: 16px;
  font-weight: 800;
  padding: 2px 10px;
  border-radius: 6px;
  margin: 0 4px;
  letter-spacing: .02em;
}
.form-field--captcha input[type="number"] {
  width: 140px;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--f);
  color: var(--dk);
  background: var(--w);
  border: 1.5px solid var(--g2);
  border-radius: var(--r);
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
  -moz-appearance: textfield;
}
.form-field--captcha input[type="number"]::-webkit-outer-spin-button,
.form-field--captcha input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; }
.form-field--captcha input:focus {
  border-color: var(--b5);
  box-shadow: 0 0 0 3px rgba(33,150,243,.12);
}
.form-field--captcha input.error {
  border-color: #dc2626;
  box-shadow: 0 0 0 3px rgba(220,38,38,.08);
}
.captcha-hint { font-size: 12px; color: var(--g5); margin-top: 6px; }

.form-field--captcha input[type="number"]::placeholder {
  font-size: 13px;
  font-weight: 400;
  color: var(--g5);
}
