/*
 * Buttons
 *
 * Developed by: Rhyll Neri
 */

.btn {
  --btn-bg: var(--color-primary);
  --btn-color: var(--color-white);
  --btn-border: var(--color-primary);

  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.95rem 1.6rem;
  font-family: var(--font-sans);
  font-size: var(--fs-14);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.02em;
  line-height: 1;
  text-decoration: none;
  border-radius: var(--radius-pill);
  background-color: var(--btn-bg);
  color: var(--btn-color);
  border: 1.5px solid var(--btn-border);
  cursor: pointer;
  transition: background-color var(--dur-200) var(--ease-out),
              border-color var(--dur-200) var(--ease-out),
              color var(--dur-200) var(--ease-out),
              transform var(--dur-200) var(--ease-out),
              box-shadow var(--dur-200) var(--ease-out);
  overflow: hidden;
  isolation: isolate;
  white-space: nowrap;
}

.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.18) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform var(--dur-500) var(--ease-out);
  z-index: -1;
}

.btn:hover::after { transform: translateX(100%); }

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

.btn:active { transform: translateY(0); }

.btn .icon { transition: transform var(--dur-200) var(--ease-out); }
.btn:hover .icon { transform: translateX(3px); }

/* ---- Variants ---- */
.btn--primary {
  --btn-bg: var(--color-primary);
  --btn-color: var(--color-white);
  --btn-border: var(--color-primary);
}
.btn--primary:hover { --btn-bg: var(--color-primary-dark); --btn-border: var(--color-primary-dark); }

.btn--accent {
  --btn-bg: var(--color-accent);
  --btn-color: var(--color-ink);
  --btn-border: var(--color-accent);
}
.btn--accent:hover { --btn-bg: var(--color-accent-dark); --btn-border: var(--color-accent-dark); --btn-color: var(--color-white); }

.btn--outline {
  --btn-bg: transparent;
  --btn-color: var(--color-primary);
  --btn-border: var(--color-primary);
}
.btn--outline:hover { --btn-bg: var(--color-primary); --btn-color: var(--color-white); }

.btn--outline-light {
  --btn-bg: transparent;
  --btn-color: var(--color-white);
  --btn-border: rgba(255,255,255,0.6);
}
.btn--outline-light:hover { --btn-bg: var(--color-white); --btn-color: var(--color-primary); --btn-border: var(--color-white); }

.btn--ink {
  --btn-bg: var(--color-ink);
  --btn-color: var(--color-white);
  --btn-border: var(--color-ink);
}

.btn--ghost {
  --btn-bg: transparent;
  --btn-color: var(--color-ink);
  --btn-border: transparent;
}
.btn--ghost:hover { --btn-color: var(--color-primary); }

.btn--text {
  --btn-bg: transparent;
  --btn-color: var(--color-primary);
  --btn-border: transparent;
  padding-left: 0;
  padding-right: 0;
  border-radius: 0;
}
.btn--text:hover { transform: none; box-shadow: none; --btn-color: var(--color-accent-dark); }

/* ---- Sizes ---- */
.btn--sm { padding: 0.65rem 1.1rem; font-size: var(--fs-12); }
.btn--lg { padding: 1.1rem 2rem; font-size: var(--fs-16); }
.btn--block { display: flex; width: 100%; }

/* ---- Icon-only button ---- */
.btn--icon {
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 50%;
}

/* Link with arrow (used in cards) */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-14);
  letter-spacing: 0.02em;
  color: var(--color-primary);
  text-transform: uppercase;
  transition: gap var(--dur-200), color var(--dur-200);
}

.link-arrow .icon { transition: transform var(--dur-200) var(--ease-out); }
.link-arrow:hover { color: var(--color-accent); gap: var(--space-3); }
.link-arrow:hover .icon { transform: translateX(2px); }

.link-arrow--lg { font-size: var(--fs-16); }
.link-arrow--inverse { color: var(--color-white); }
.link-arrow--inverse:hover { color: var(--color-accent); }
