/* 4. css/components.css - Reusable components */
/* ---------------------------------------- */

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md) var(--space-xl);
    font-size: var(--text-base);
    font-weight: 500;
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
    cursor: pointer;
    border: none;
    text-align: center;
}

.btn--primary {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.btn--primary:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.btn--secondary {
    background-color: var(--color-secondary);
    color: var(--color-white);
}

.btn--secondary:hover {
    background-color: var(--color-secondary-dark);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* Social Icons */
.social-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.2rem;
    height: 3.2rem;
    border-radius: var(--radius-full);
    background-color: rgba(255, 255, 255, 0.1);
    color: var(--color-white);
    transition: all var(--transition-base);
}

.social-icon:hover {
    background-color: var(--color-primary);
    transform: scale(1.1);
}

/* Service Card */
.service-card {
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    text-align: center;
    transition: all var(--transition-base);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 22rem;
}

.service-card:hover {
    transform: translateY(-10px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-primary);
}

.service-card__link {
    display: block;
}

.service-card__icon {
    font-size: 6rem; /* Aumentado para asegurar visibilidad */
    color: var(--color-accent-brown);
    margin-bottom: var(--space-lg);
    transition: transform var(--transition-base);
    line-height: 1;
    width: 6rem; /* Ancho y alto para centrar mejor */
    height: 6rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.service-card:hover .service-card__icon {
    transform: rotate(15deg) scale(1.1); /* Efecto de rotación y escala */
}

.service-card__icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.service-card__title {
    font-size: var(--text-md);
    color: var(--color-secondary);
    font-weight: 600;
    line-height: 1.4;
}




/* ===== Toast global (top-right, moderno) ===== */
.toast-container{
  position: fixed;
  top: 1rem; right: 1rem;
  display: flex; flex-direction: column; gap: .5rem;
  z-index: 9999;                 /* ⬅️ MUY importante: por encima de header/whatsapp */
  pointer-events: none;
}

.toast{
  pointer-events: auto;
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-left: 6px solid var(--color-primary);
  border-radius: 14px;
  box-shadow: var(--shadow-lg);
  padding: .95rem 1.1rem .85rem 1.1rem;
  min-width: 300px; max-width: 460px;

  display: grid; grid-template-columns: auto 1fr auto;
  align-items: start; gap: .85rem;

  transform: translateY(-12px);
  opacity: 0;
  transition: transform .22s ease, opacity .22s ease, filter .2s ease;
}

.toast.show{ transform: translateY(0); opacity: 1; }
.toast:hover{ filter: brightness(.98); }

.toast--success{ border-left-color: var(--color-accent-green); }
.toast--error  { border-left-color: #9c2e2e; }
.toast--info   { border-left-color: var(--color-primary); }

.toast__icon{
  margin-top:.1rem;
  font-size: 1.6rem;             /* ⬅️ icono más grande */
  line-height: 1;
  opacity:.9;
}

.toast__msg{
  font-size: var(--text-base);   /* ⬅️ 1.6rem con tu escala (16px aprox) */
  line-height: 1.5;
}

.toast__close{
  background: transparent; border: 0; cursor: pointer;
  font-size: 1.5rem;             /* ⬅️ botón más legible */
  line-height: 1; padding: .15rem .25rem;
  border-radius: var(--radius-sm);
}
.toast__close:hover{ filter: brightness(.9); }

/* Barra de progreso */
.toast__bar{
  grid-column: 1 / -1;
  height: 3px; margin-top: .6rem;
  background: currentColor; opacity: .35; border-radius: 0 0 10px 10px;
  transform-origin: left center;
  animation-name: toastbar; animation-timing-function: linear;
}
.toast--success .toast__bar{ background: var(--color-accent-green); opacity:.5; }
.toast--error   .toast__bar{ background: #9c2e2e; opacity:.5; }
.toast--info    .toast__bar{ background: var(--color-primary); opacity:.5; }

@keyframes toastbar{ from{transform:scaleX(1)} to{transform:scaleX(0)} }

/* Responsivo: ancho completo en móvil y margen con safe-area */
@media (max-width: 768px){
  .toast-container{
    top: max(1rem, env(safe-area-inset-top));
    left: max(.75rem, env(safe-area-inset-left));
    right: max(.75rem, env(safe-area-inset-right));
  }
  .toast{ max-width: none; width: 100%; }
}