/* ============================================================
   PDE Performance — Components (glass-effect2 system)
   ============================================================ */

/* ── Animatable border angle ── */
@property --btn-angle {
  syntax: '<angle>';
  inherits: false;
  initial-value: 0deg;
}

@keyframes btn-border-spin {
  0%   { --btn-angle:   0deg; }
  72%  { --btn-angle: 360deg; }
  100% { --btn-angle: 360deg; } /* ~1s pause entre ciclos */
}

/* ── Primary Button ── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  background: var(--red);
  color: #fff;
  font-family: var(--ff-h);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 12px;
  border: none;
  text-decoration: none;
  transition: background 0.3s var(--ease), color 0.3s var(--ease), transform 0.3s var(--ease);
  cursor: pointer;
  position: relative;
  isolation: isolate;
}
.btn-primary::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 14px;
  background: conic-gradient(
    from var(--btn-angle),
    transparent 0%,
    transparent 63%,
    rgba(228, 30, 38, 0.35) 70%,
    rgba(255, 80,  80, 1.00) 80%,
    rgba(228, 30, 38, 0.35) 90%,
    transparent 100%
  );
  animation: btn-border-spin 3.5s ease-in-out infinite;
  z-index: -1;
  filter: blur(2.5px);
}
.btn-primary:hover {
  background: #fff;
  color: var(--red);
  transform: translateY(-2px);
}

/* ── Secondary Button (glass) ── */
.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  background: var(--glass);
  color: var(--t1);
  font-family: var(--ff-h);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 12px;
  border-top: 1px solid var(--border-t);
  border-left: 1px solid var(--border-s);
  border-right: 1px solid var(--border-s);
  border-bottom: 1px solid var(--border-b);
  text-decoration: none;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: background 0.3s var(--ease), color 0.3s var(--ease), transform 0.3s, border-color 0.3s;
  cursor: pointer;
  position: relative;
  isolation: isolate;
}
.btn-secondary::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 14px;
  background: conic-gradient(
    from var(--btn-angle),
    transparent 0%,
    transparent 63%,
    rgba(255, 255, 255, 0.10) 70%,
    rgba(255, 255, 255, 0.45) 80%,
    rgba(255, 255, 255, 0.10) 90%,
    transparent 100%
  );
  animation: btn-border-spin 3.5s ease-in-out infinite;
  animation-delay: -1.2s; /* dessincroniza dos botões vermelhos */
  z-index: -1;
  filter: blur(2px);
}
.btn-secondary:hover {
  background: #fff;
  color: #000;
  border-color: #fff;
  transform: translateY(-2px);
}

/* ── Ghost button ── */
.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 0;
  background: none;
  border: none;
  color: var(--t2);
  font-family: var(--ff-h);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: color 0.3s;
  position: relative;
}
.btn-ghost::after {
  content: '';
  position: absolute;
  bottom: 6px; left: 0; right: 0;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s var(--spring);
}
.btn-ghost:hover { color: var(--t1); }
.btn-ghost:hover::after { transform: scaleX(1); }

/* ── Plan button ── */
.plan-btn {
  display: block;
  width: 100%;
  padding: 13px;
  border-radius: 12px;
  font-family: var(--ff-h);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  text-decoration: none;
  transition: all 0.3s var(--ease);
  cursor: pointer;
  margin-top: auto;
  position: relative;
  isolation: isolate;
}
.plan-card.featured .plan-btn {
  background: var(--red);
  color: #fff;
  border: 1px solid transparent;
}
.plan-card.featured .plan-btn::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 14px;
  background: conic-gradient(
    from var(--btn-angle),
    transparent 0%,
    transparent 63%,
    rgba(228, 30, 38, 0.35) 70%,
    rgba(255, 80,  80, 1.00) 80%,
    rgba(228, 30, 38, 0.35) 90%,
    transparent 100%
  );
  animation: btn-border-spin 3.5s ease-in-out infinite;
  animation-delay: -0.8s;
  z-index: -1;
  filter: blur(2.5px);
}
.plan-card.featured .plan-btn:hover {
  background: #fff;
  color: var(--red);
  transform: translateY(-2px);
}
.plan-card:not(.featured) .plan-btn {
  background: var(--glass);
  color: var(--t1);
  border-top: 1px solid var(--border-t);
  border-left: 1px solid var(--border-s);
  border-right: 1px solid var(--border-s);
  border-bottom: 1px solid var(--border-b);
  backdrop-filter: blur(12px);
}
.plan-card:not(.featured) .plan-btn:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.3);
  transform: translateY(-2px);
}

/* ── Badges ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 9999px;
  font-family: var(--ff-h);
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.badge-default {
  background: var(--glass);
  border-top: 1px solid var(--border-t);
  border-left: 1px solid var(--border-s);
  border-right: 1px solid var(--border-s);
  border-bottom: 1px solid var(--border-b);
  color: var(--t2);
}
.badge-red {
  background: var(--red-a10);
  border: 1px solid var(--red-a20);
  color: var(--red-s);
}
.badge-teal {
  background: var(--teal-a);
  border: 1px solid rgba(32,217,160,0.25);
  color: var(--teal);
}
.badge-amber {
  background: var(--amber-a);
  border: 1px solid rgba(245,158,11,0.25);
  color: var(--amber);
}

/* ── Inline link ── */
.lk {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.9rem;
  transition: gap 0.3s, opacity 0.3s;
}
.lk::after { content: ' ›'; }
.lk:hover { opacity: 0.75; gap: 8px; }

.lk-teal { color: var(--teal); }
.lk-amber { color: var(--amber); }
.lk-red   { color: var(--red-s); }

/* ── Dividers ── */
.hr {
  height: 1px;
  background: var(--border-b);
  border: none;
  margin: 0;
}

/* ── Iconify ── */
iconify-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
}
