/* ============================================================
   INDAGO Labs — Components CSS
   Botones, cards, badges, tags, formularios
   ============================================================ */

/* ============================================================
   BOTONES
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wide);
  line-height: 1;
  padding: 0.875rem 1.75rem;
  border-radius: var(--radius-pill);
  border: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  transition: var(--transition-base);
  position: relative;
  overflow: hidden;
}

/* PRIMARY — Naranja brillante (acción, conversión) */
.btn--primary {
  background: var(--gradient-cta-btn);
  color: #ffffff;
  border-color: transparent;
  box-shadow: 0 4px 14px var(--orange-cta-shadow);
}
.btn--primary:hover {
  background: var(--gradient-cta-btn-hover);
  box-shadow: 0 6px 20px var(--orange-cta-shadow);
  transform: translateY(-2px);
  color: #ffffff;
}
.btn--primary:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

/* GHOST — Contorno azul sobre fondo blanco */
.btn--ghost {
  background: transparent;
  color: var(--blue-primary);
  border-color: var(--blue-primary);
}
.btn--ghost:hover {
  background: var(--blue-light);
  color: var(--blue-hover);
  border-color: var(--blue-hover);
  transform: translateY(-2px);
}

/* GHOST ON DARK — Contorno blanco sobre fondo navy */
.btn--ghost-dark {
  background: transparent;
  color: var(--text-on-dark);
  border-color: rgba(255,255,255,0.5);
}
.btn--ghost-dark:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--text-on-dark);
  color: var(--text-on-dark);
  transform: translateY(-2px);
}

/* DANGER — Para emergencias/incidentes */
.btn--danger {
  background: var(--amber-urgent);
  color: var(--text-on-dark);
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(217,119,6,0.35);
}
.btn--danger:hover {
  background: var(--amber-mid);
  box-shadow: 0 6px 20px rgba(217,119,6,0.45);
  transform: translateY(-2px);
  color: var(--text-on-dark);
}

/* TEXTO — Solo texto con flecha */
.btn--text {
  background: transparent;
  color: var(--blue-primary);
  border-color: transparent;
  padding-inline: 0;
  padding-block: var(--space-2);
  border-radius: 0;
  font-weight: var(--weight-semibold);
}
.btn--text:hover {
  color: var(--blue-hover);
  transform: none;
  gap: var(--space-3);
}
.btn--text:hover .btn__arrow {
  transform: translateX(4px);
}
.btn__arrow {
  transition: transform var(--duration-base) var(--ease-out);
  flex-shrink: 0;
}

/* SIZES */
.btn--sm {
  font-size: var(--text-sm);
  padding: 0.625rem 1.25rem;
}
.btn--lg {
  font-size: var(--text-lg);
  padding: 1.1rem 2.25rem;
}

/* ============================================================
   CARDS — Base
   ============================================================ */
.card {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-light);
  padding: var(--space-8);
  box-shadow: var(--shadow-card);
  transition: var(--transition-card);
  position: relative;
  overflow: hidden;
}

.card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
  border-color: var(--border-medium);
}

/* CARD SERVICE — Con left border azul (firma Deloitte) */
.card-service {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-light);
  border-left: 5px solid var(--blue-signature);
  padding: var(--space-8) var(--space-8) var(--space-8) calc(var(--space-8) - 4px);
  box-shadow: var(--shadow-card);
  transition: var(--transition-card);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.card-service:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

/* Variantes de color para el left-border */
.card-service--teal   { border-left-color: var(--teal-accent); }
.card-service--blue   { border-left-color: var(--blue-primary); }
.card-service--navy   { border-left-color: var(--navy-mid); }
.card-service--green  { border-left-color: var(--green-success); }
.card-service--amber  { border-left-color: var(--amber-urgent); }
.card-service--mid    { border-left-color: var(--blue-mid); }

.card-service__icon {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--blue-light);
  border-radius: var(--radius-md);
  color: var(--blue-primary);
  flex-shrink: 0;
}

.card-service--teal   .card-service__icon { background: var(--teal-light); color: var(--teal-accent); }
.card-service--navy   .card-service__icon { background: var(--blue-pale); color: var(--navy-mid); }
.card-service--green  .card-service__icon { background: var(--green-light); color: var(--green-success); }
.card-service--amber  .card-service__icon { background: var(--amber-light); color: var(--amber-urgent); }
.card-service--mid    .card-service__icon { background: var(--blue-light); color: var(--blue-mid); }

.card-service__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  line-height: var(--leading-snug);
  margin: 0;
}

.card-service__desc {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  flex-grow: 1;
}

.card-service__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.card-service__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--blue-primary);
  margin-top: var(--space-2);
  transition: gap var(--duration-base) ease, color var(--duration-fast) ease;
}
.card-service__link:hover {
  color: var(--blue-hover);
  gap: var(--space-3);
}

/* CARD DIFFERENTIATOR */
.card-diff {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-light);
  border-left: 4px solid var(--blue-signature);
  padding: var(--space-8);
  box-shadow: var(--shadow-card);
  transition: var(--transition-card);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.card-diff:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-3px);
}

.card-diff__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--green-light);
  border-radius: var(--radius-md);
  color: var(--green-success);
  flex-shrink: 0;
}

.card-diff__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  line-height: var(--leading-snug);
}

.card-diff__desc {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
}

/* CARD CASO */
.card-case {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  border: 1px solid var(--border-light);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: var(--transition-card);
  display: flex;
  flex-direction: column;
}
.card-case:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

.card-case__header {
  padding: var(--space-6) var(--space-8) 0;
}
.card-case__body {
  padding: var(--space-6) var(--space-8);
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.card-case__metrics {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-8);
  border-top: 1px solid var(--border-light);
  background: var(--bg-light);
}
.card-case__metric {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  flex: 1;
}
.card-case__metric-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--weight-extrabold);
  color: var(--navy-primary);
}
.card-case__metric-label {
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}

/* Card caso confidencial */
.card-case--nda {
  position: relative;
}
.card-case--nda .card-case__body,
.card-case--nda .card-case__metrics {
  filter: blur(4px);
  user-select: none;
  pointer-events: none;
}
.card-case__nda-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  z-index: var(--z-raised);
}
.card-case__nda-icon {
  width: 56px;
  height: 56px;
  background: rgba(255,255,255,0.95);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-sm);
  color: var(--navy-primary);
}
.card-case__nda-text {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--navy-primary);
  background: rgba(255,255,255,0.95);
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-sm);
}

/* CARD TESTIMONIO */
.card-testimonial {
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.card-testimonial__quote {
  font-size: var(--text-lg);
  font-style: italic;
  color: rgba(255,255,255,0.90);
  line-height: var(--leading-loose);
}

.card-testimonial__author {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.card-testimonial__avatar {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-full);
  object-fit: cover;
  border: 2px solid rgba(255,255,255,0.2);
  flex-shrink: 0;
}

.card-testimonial__name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: var(--weight-bold);
  color: var(--text-on-dark);
}

.card-testimonial__role {
  font-size: var(--text-sm);
  color: var(--text-on-dark-2);
}

/* CARD INSIGHT */
.card-insight {
  background: var(--bg-card);
  border-radius: var(--radius-xl);
  border: 1px solid var(--border-light);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: var(--transition-card);
  display: flex;
  flex-direction: column;
}
.card-insight:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}
.card-insight__image {
  width: 100%;
  height: 200px;
  object-fit: cover;
  background: var(--bg-light);
}
.card-insight__img-placeholder {
  width: 100%;
  height: 200px;
  background: linear-gradient(135deg, var(--blue-light) 0%, var(--bg-light) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue-primary);
}
.card-insight__body {
  padding: var(--space-6) var(--space-8);
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* ============================================================
   BADGES Y TAGS
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-regular);
  letter-spacing: var(--tracking-wide);
  padding: 0.25rem 0.625rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  white-space: nowrap;
}

.badge--blue {
  background: var(--blue-light);
  color: var(--blue-primary);
  border-color: rgba(30,106,240,0.15);
}

.badge--teal {
  background: var(--teal-light);
  color: var(--teal-accent);
  border-color: rgba(8,145,178,0.15);
}

.badge--green {
  background: var(--green-light);
  color: var(--green-success);
  border-color: rgba(5,150,105,0.15);
}

.badge--amber {
  background: var(--amber-light);
  color: var(--amber-urgent);
  border-color: rgba(217,119,6,0.15);
}

.badge--navy {
  background: var(--blue-pale);
  color: var(--navy-mid);
  border-color: rgba(0,51,153,0.15);
}

/* PILL — Para los trust pills del hero */
.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: rgba(255,255,255,0.80);
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: var(--radius-pill);
  padding: 0.5rem 1rem;
  backdrop-filter: blur(8px);
}

.pill__icon {
  font-size: 1rem;
  line-height: 1;
}

/* SECTOR TAG */
.sector-tag {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--blue-primary);
  padding: 0.25rem 0.75rem;
  background: var(--blue-light);
  border-radius: var(--radius-pill);
}

/* INSIGHT TYPE BADGE */
.insight-badge {
  display: inline-flex;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--text-muted);
  border-bottom: 2px solid var(--blue-signature);
  padding-bottom: 2px;
}

/* ============================================================
   FORMULARIO — Estilo Material/Google
   ============================================================ */
.form-group {
  position: relative;
  margin-bottom: var(--space-6);
}

.form-label {
  display: block;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
  transition: color var(--duration-fast) ease;
}

.form-group:focus-within .form-label {
  color: var(--blue-primary);
}

.form-input,
.form-textarea,
.form-select {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text-primary);
  background: var(--bg-input);
  border: 1px solid var(--border-medium);
  border-radius: var(--radius-md);
  padding: 0.75rem 1rem;
  transition: border-color var(--duration-fast) ease,
              box-shadow var(--duration-fast) ease;
  outline: none;
  appearance: none;
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
  border-color: var(--border-focus);
  box-shadow: var(--shadow-input-focus);
  background: var(--bg-white);
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--text-placeholder);
}

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

.form-select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748B' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

/* URGENCIA RADIO GROUP */
.urgency-group {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.urgency-option {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.urgency-option input[type="radio"] {
  accent-color: var(--blue-primary);
  width: 16px;
  height: 16px;
  cursor: pointer;
}

/* ERROR STATE */
.form-input--error {
  border-color: var(--red-error);
}
.form-error {
  font-size: var(--text-xs);
  color: var(--red-error);
  margin-top: var(--space-1);
  display: none;
}
.form-error.visible {
  display: block;
}

/* SUBMIT STATE MESSAGES */
.form-success {
  display: none;
  padding: var(--space-6);
  background: var(--green-light);
  border: 1px solid rgba(5,150,105,0.2);
  border-radius: var(--radius-lg);
  text-align: center;
  color: var(--green-success);
  font-weight: var(--weight-semibold);
}

/* ============================================================
   STAT ITEMS
   ============================================================ */
.stat-item {
  text-align: center;
  padding: var(--space-8);
  position: relative;
}

.stat-item + .stat-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  height: 60%;
  width: 1px;
  background: var(--border-light);
}

.stat-number {
  font-family: var(--font-display);
  font-size: var(--text-stat);
  font-weight: var(--weight-extrabold);
  color: var(--navy-primary);
  line-height: var(--leading-none);
  display: block;
  margin-bottom: var(--space-3);
  letter-spacing: var(--tracking-tight);
}

.stat-label {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}

/* ============================================================
   CERT BADGE
   ============================================================ */
.cert-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-6);
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-card);
  cursor: default;
  text-align: center;
}

.cert-badge:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-3px);
  border-color: var(--blue-signature);
}

.cert-badge__logo {
  font-size: 2rem;
  line-height: 1;
}

.cert-badge__name {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--text-muted);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
}

/* ============================================================
   CONTACT INFO CARD
   ============================================================ */
.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

.contact-info-item__icon {
  width: 44px;
  height: 44px;
  background: var(--blue-light);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue-primary);
  flex-shrink: 0;
}

.contact-info-item__label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  margin-bottom: var(--space-1);
}

.contact-info-item__value {
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--text-primary);
}

/* PANEL DE URGENCIA */
.urgency-panel {
  background: var(--amber-light);
  border: 2px solid var(--amber-urgent);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.urgency-panel__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--amber-urgent);
}

.urgency-panel__desc {
  font-size: var(--text-sm);
  color: var(--text-body);
  line-height: var(--leading-normal);
}
