/* Styles for contact page */
/* ============================================================
   PAGE: contact.css
   Stiluri specifice /contact/
   Variabile din tokens.css
   ============================================================ */

/* ── Breadcrumb ─────────────────────────────────────────────── */

/* ══════════════════════════════════════════════════════════════
   HERO CONTACT
   ══════════════════════════════════════════════════════════════ */
.contact-hero {
  padding: var(--space-12) 0 var(--space-16);
  background: linear-gradient(145deg, #0f172a 0%, #1e3a5f 50%, #1a365d 100%);
}

.contact-hero-inner {
  display: grid;
  grid-template-columns: 1fr 520px;
  gap: var(--space-12);
  align-items: flex-start;
}
@media (max-width: 1024px) {
  .contact-hero-inner { grid-template-columns: 1fr; }
}

/* Copy */
.contact-hero-text .eyebrow { color: var(--color-accent); margin-bottom: var(--space-3); }
.contact-hero-text h1 {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: var(--fw-extrabold);
  color: var(--color-white);
  line-height: 1.2;
  font-family: var(--font-display);
  margin-bottom: var(--space-4);
}
.contact-hero-text > p {
  font-size: var(--fs-lg);
  color: rgba(255,255,255,0.75);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-8);
}

/* Quick contact cards */
.contact-quick-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
}
@media (max-width: 480px) {
  .contact-quick-cards { grid-template-columns: 1fr; }
}

.contact-quick-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-xl);
  padding: var(--space-4) var(--space-5);
  text-decoration: none;
  transition: background var(--transition-fast), border-color var(--transition-fast);
  cursor: pointer;
}
.contact-quick-card:hover {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.2);
}
.contact-quick-card--primary {
  border-color: rgba(0,200,150,0.4);
  background: rgba(0,200,150,0.1);
}
.contact-quick-card--primary:hover { background: rgba(0,200,150,0.16); }
.contact-quick-card--wa {
  border-color: rgba(37,211,102,0.4);
  background: rgba(37,211,102,0.08);
}
.contact-quick-card--wa:hover { background: rgba(37,211,102,0.14); }
.contact-quick-card--schedule { cursor: default; }

.contact-quick-card__icon {
  width: 44px; height: 44px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,0.1);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.contact-quick-card--primary .contact-quick-card__icon { background: rgba(0,200,150,0.2); fill: var(--color-accent); }
.contact-quick-card--wa .contact-quick-card__icon { background: rgba(37,211,102,0.2); fill: #25d366; }
.contact-quick-card .contact-quick-card__icon { fill: rgba(255,255,255,0.7); }

.contact-quick-card__content { display: flex; flex-direction: column; gap: 2px; }
.contact-quick-card__content strong {
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.contact-quick-card__content span {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-white);
}

/* Trust list */
.contact-trust {
  list-style: none;
  display: flex; flex-direction: column; gap: var(--space-3);
}
.contact-trust li {
  display: flex; align-items: center; gap: var(--space-3);
  font-size: var(--fs-sm); color: rgba(255,255,255,0.75);
}
.contact-trust svg { fill: var(--color-accent); flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════════
   FORMULAR CARD
   ══════════════════════════════════════════════════════════════ */
.contact-form-card {
  background: var(--color-white);
  border-radius: var(--radius-2xl);
  box-shadow: 0 24px 64px rgba(0,0,0,0.35);
  padding: var(--space-8);
  position: relative;
}

.contact-form-card__header { margin-bottom: var(--space-6); }
.contact-form-card__title {
  font-size: var(--fs-xl); font-weight: var(--fw-bold);
  color: var(--color-gray-900); font-family: var(--font-display);
  margin-bottom: var(--space-1);
}
.contact-form-card__sub { font-size: var(--fs-sm); color: var(--color-gray-500); }

/* Form fields */
.cf-form { display: flex; flex-direction: column; gap: var(--space-4); }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
@media (max-width: 600px) { .cf-row { grid-template-columns: 1fr; } }

.cf-field { display: flex; flex-direction: column; gap: var(--space-1); }
.cf-field--full { grid-column: 1 / -1; }

.cf-field label {
  font-size: var(--fs-sm); font-weight: var(--fw-medium);
  color: var(--color-gray-700);
}
.cf-field label span[aria-hidden="true"] { color: var(--color-error); }
.cf-optional { font-weight: var(--fw-regular); color: var(--color-gray-400); }

.cf-field input,
.cf-field select,
.cf-field textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  font-size: var(--fs-sm);
  color: var(--color-gray-800);
  background: var(--color-white);
  font-family: var(--font-body);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  -webkit-appearance: none; appearance: none;
}
.cf-field textarea { resize: vertical; min-height: 100px; line-height: var(--lh-relaxed); }
.cf-field input:focus,
.cf-field select:focus,
.cf-field textarea:focus {
  outline: none;
  border-color: var(--color-primary-light);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.12);
}
.cf-field input.cf-invalid,
.cf-field select.cf-invalid { border-color: var(--color-error); }

.cf-select-wrap { position: relative; }
.cf-select-wrap select { padding-right: var(--space-10); cursor: pointer; }
.cf-select-arrow {
  position: absolute; right: var(--space-3); top: 50%;
  transform: translateY(-50%);
  fill: var(--color-gray-400); pointer-events: none;
}
.cf-error {
  font-size: var(--fs-xs); color: var(--color-error);
  min-height: 16px; display: block;
}
.cf-gdpr-error { margin-top: calc(-1 * var(--space-2)); }

/* Checkbox */
.cf-checkbox {
  display: flex; align-items: flex-start; gap: var(--space-3);
  cursor: pointer; font-size: var(--fs-xs);
  color: var(--color-gray-600); line-height: 1.5;
}
.cf-checkbox input[type="checkbox"] { position: absolute; opacity: 0; width: 0; height: 0; }
.cf-checkbox-custom {
  width: 18px; height: 18px; min-width: 18px;
  border: 2px solid var(--color-gray-300);
  border-radius: var(--radius-sm); margin-top: 1px;
  transition: all var(--transition-fast); background: var(--color-white);
  display: flex; align-items: center; justify-content: center;
}
.cf-checkbox input:checked ~ .cf-checkbox-custom {
  background: var(--color-primary); border-color: var(--color-primary);
}
.cf-checkbox input:checked ~ .cf-checkbox-custom::after {
  content: '✓'; color: white; font-size: 11px; font-weight: bold;
}
.cf-checkbox a { color: var(--color-primary-light); text-decoration: underline; }

.cf-submit {
  width: 100%; font-size: var(--fs-base);
  font-weight: var(--fw-bold); padding: var(--space-4);
}
.cf-note {
  font-size: var(--fs-xs); color: var(--color-gray-400);
  text-align: center; margin-top: var(--space-1);
}
.cf-note a { color: var(--color-primary); font-weight: var(--fw-semibold); }

/* Succes */
.cf-success {
  text-align: center; padding: var(--space-10) var(--space-4);
  display: flex; flex-direction: column; align-items: center; gap: var(--space-4);
}
.cf-success[hidden] { display: none; }
.cf-success__icon {
  width: 72px; height: 72px; background: var(--color-accent);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 2rem; color: white; font-weight: bold;
}
.cf-success h3 { font-size: var(--fs-2xl); font-weight: var(--fw-bold); color: var(--color-gray-900); }
.cf-success p { font-size: var(--fs-base); color: var(--color-gray-600); line-height: var(--lh-relaxed); }
.cf-success a[href] { color: var(--color-primary); font-weight: var(--fw-bold); }

/* ══════════════════════════════════════════════════════════════
   INFO SECTION
   ══════════════════════════════════════════════════════════════ */
.contact-info-section { padding: var(--space-16) 0; }

.contact-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: flex-start;
}
@media (max-width: 768px) { .contact-info-grid { grid-template-columns: 1fr; } }

.contact-info-block h2 {
  font-size: var(--fs-2xl); font-weight: var(--fw-bold);
  color: var(--color-gray-900); margin-bottom: var(--space-6);
}

/* Address items */
.contact-address { display: flex; flex-direction: column; gap: var(--space-4); margin-bottom: var(--space-8); }
.contact-address-item {
  display: flex; gap: var(--space-4); align-items: flex-start;
}
.contact-address-item__icon {
  width: 44px; height: 44px; border-radius: var(--radius-lg);
  background: rgba(37,99,235,0.08);
  display: flex; align-items: center; justify-content: center;
  fill: var(--color-primary-light); flex-shrink: 0;
}
.contact-address-item__label {
  display: block; font-size: var(--fs-xs);
  color: var(--color-gray-400); text-transform: uppercase;
  letter-spacing: 0.04em; font-weight: var(--fw-semibold);
  margin-bottom: 2px;
}
.contact-address-item__value {
  display: block; font-size: var(--fs-base);
  color: var(--color-gray-800); font-weight: var(--fw-medium);
  text-decoration: none; transition: color var(--transition-fast);
}
a.contact-address-item__value:hover { color: var(--color-primary-light); }

/* Process steps */
.contact-steps { margin-top: var(--space-2); }
.contact-steps h3 {
  font-size: var(--fs-base); font-weight: var(--fw-semibold);
  color: var(--color-gray-900); margin-bottom: var(--space-5);
}
.contact-steps-list { list-style: none; display: flex; flex-direction: column; gap: 0; }
.contact-steps-list li {
  display: flex; gap: var(--space-4); align-items: flex-start;
  padding-bottom: var(--space-5); position: relative;
}
.contact-steps-list li:not(:last-child)::after {
  content: ''; position: absolute;
  left: 18px; top: 40px;
  width: 2px; height: calc(100% - 40px);
  background: var(--color-gray-200);
}
.contact-step-num {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--color-accent); color: white;
  font-family: var(--font-display); font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; position: relative; z-index: 1;
}
.contact-steps-list li div strong {
  display: block; font-size: var(--fs-sm);
  font-weight: var(--fw-semibold); color: var(--color-gray-900);
  margin-bottom: var(--space-1); margin-top: var(--space-2);
}
.contact-steps-list li div p {
  font-size: var(--fs-sm); color: var(--color-gray-500);
  line-height: var(--lh-relaxed); margin: 0;
}

/* Map */
.contact-map-wrap {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  margin-bottom: var(--space-5);
  border: 1px solid var(--color-gray-200);
}

/* Free plan card */
.contact-free-card {
  background: linear-gradient(135deg, rgba(0,200,150,0.06) 0%, var(--color-white) 100%);
  border: 2px solid var(--color-accent);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.contact-free-card__badge {
  display: inline-flex;
}
.contact-free-card__badge span {
  background: var(--color-accent); color: white;
  font-size: var(--fs-sm); font-weight: var(--fw-bold);
  padding: var(--space-1) var(--space-4);
  border-radius: var(--radius-full);
}
.contact-free-card h3 {
  font-size: var(--fs-lg); font-weight: var(--fw-semibold);
  color: var(--color-gray-900);
}
.contact-free-card p {
  font-size: var(--fs-sm); color: var(--color-gray-600);
  line-height: var(--lh-relaxed); margin: 0;
}
.contact-free-card .btn { align-self: flex-start; }
.contact-free-card__compare {
  font-size: var(--fs-sm); color: var(--color-primary-light);
  text-decoration: none; font-weight: var(--fw-medium);
  transition: color var(--transition-fast);
}
.contact-free-card__compare:hover { color: var(--color-primary); }

/* ══════════════════════════════════════════════════════════════
   FAQ CONTACT
   ══════════════════════════════════════════════════════════════ */
.contact-faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-2);
}
@media (max-width: 768px) { .contact-faq-grid { grid-template-columns: 1fr; } }

.contact-faq-item {
  background: var(--color-white);
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  transition: box-shadow var(--transition-base);
}
.contact-faq-item:hover { box-shadow: var(--shadow-md); }
.contact-faq-item h3 {
  font-size: var(--fs-base); font-weight: var(--fw-semibold);
  color: var(--color-gray-900); margin-bottom: var(--space-3);
}
.contact-faq-item p {
  font-size: var(--fs-sm); color: var(--color-gray-600);
  line-height: var(--lh-relaxed); margin: 0;
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 768px) {
  .contact-hero { padding: var(--space-10) 0 var(--space-12); }
  .contact-form-card { padding: var(--space-6); }
  .contact-quick-cards { grid-template-columns: 1fr; }
}
