/* ==========================================
   COMPONENTS.CSS – Reusable UI elements
   ========================================== */

/* ---- Buttons ---- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 0.625rem 1.375rem;
  border-radius: var(--r-full);
  font-weight: var(--fw-semibold);
  font-size: var(--text-sm);
  line-height: 1;
  transition: all var(--t-med);
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
  letter-spacing: 0.01em;
}

.btn-primary {
  background: var(--clr-primary);
  color: var(--clr-on-primary);
  box-shadow: 0 0 0 0 var(--clr-primary-glow);
}
.btn-primary:hover {
  background: var(--clr-primary-dark);
  box-shadow: 0 4px 24px var(--clr-primary-glow);
  transform: translateY(-1px);
}
.btn-primary:active { transform: translateY(0); }

.btn-ghost {
  background: transparent;
  color: var(--clr-text);
  border: 1px solid var(--clr-border-med);
}
.btn-ghost:hover {
  background: var(--clr-surface);
  border-color: var(--clr-border-str);
}

.btn-sm  { padding: 0.45rem 1rem; font-size: var(--text-xs); }
.btn-lg  { padding: 0.75rem 1.75rem; font-size: var(--text-base); }
.btn-xl  { padding: 0.875rem 2rem; font-size: var(--text-lg); }

/* ---- Pill / Badge ---- */
.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 0.3rem 0.875rem;
  border-radius: var(--r-full);
  background: var(--clr-primary-dim);
  border: 1px solid color-mix(in srgb, var(--clr-primary) 28%, transparent);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-primary);
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.pill-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--clr-primary);
  animation: pulse-green 2s infinite;
}

@keyframes pulse-green {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* ---- Eyebrow label ---- */
.eyebrow {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: var(--sp-3);
}
.eyebrow--blue   { color: var(--clr-blue); }
.eyebrow--purple { color: var(--clr-purple); }
.eyebrow--orange { color: var(--clr-orange); }
.eyebrow--green  { color: var(--clr-primary); }

/* ---- Text gradients ---- */
.text-gradient {
  background: linear-gradient(135deg, var(--clr-primary) 0%, var(--clr-blue) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-gradient-blue {
  background: linear-gradient(135deg, var(--clr-blue) 0%, #4338ca 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-gradient-purple {
  background: linear-gradient(135deg, var(--clr-purple) 0%, var(--clr-pink-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-gradient-orange {
  background: linear-gradient(135deg, var(--clr-orange) 0%, var(--clr-yellow) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ---- Utility color classes ---- */
.text-primary { color: var(--clr-primary); }
.text-warning  { color: var(--clr-yellow); }
.text-danger   { color: var(--clr-red); }
.text-blue     { color: var(--clr-blue); }

/* ---- Section headers ---- */
.section-header {
  max-width: 680px;
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.section-header--center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
.section-header--left { margin-left: 0; }

.section-desc {
  font-size: var(--text-lg);
  color: var(--clr-text-muted);
  margin-top: var(--sp-4);
  line-height: 1.7;
}

/* ---- Image Stack (with tabs) ---- */
.img-stack {
  position: relative;
  border-radius: var(--r-xl);
  overflow: hidden;
  background: var(--clr-surface);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--clr-border);
  aspect-ratio: 16 / 10;
}

.img-stack__item {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity var(--t-slow);
  border-radius: var(--r-xl);
}

.img-stack__item--active {
  opacity: 1;
}

/* ---- Image Tabs ---- */
.img-tabs {
  display: flex;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
  flex-wrap: wrap;
}

.img-tab {
  padding: 0.4rem 1rem;
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-muted);
  border: 1px solid var(--clr-border);
  background: var(--clr-surface);
  cursor: pointer;
  transition: all var(--t-med);
  letter-spacing: 0.02em;
}

.img-tab:hover {
  color: var(--clr-text);
  border-color: var(--clr-border-med);
}

.img-tab--active {
  color: var(--clr-primary);
  border-color: color-mix(in srgb, var(--clr-primary) 38%, transparent);
  background: var(--clr-primary-dim);
}

/* ---- Browser frame ---- */
.ss-browser-frame {
  background: var(--clr-surface-2);
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--clr-border-med);
  box-shadow: var(--shadow-lg);
}
.ss-browser-frame--sm { border-radius: var(--r-md); }

.ss-browser-bar {
  display: flex;
  gap: 6px;
  padding: 10px 14px;
  background: linear-gradient(180deg, var(--clr-bg-1) 0%, var(--clr-bg-2) 100%);
  border-bottom: 1px solid var(--clr-border);
}
.ss-browser-bar span {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
}
.ss-browser-bar span:nth-child(1) { background: #ff5f57; }
.ss-browser-bar span:nth-child(2) { background: #febc2e; }
.ss-browser-bar span:nth-child(3) { background: #28c840; }

.ss-browser-frame img {
  width: 100%;
  display: block;
}

/* ---- FAQ ---- */
.faq-item {
  border-bottom: 1px solid var(--clr-border);
}

.faq-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: var(--sp-5) 0;
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  text-align: left;
  gap: var(--sp-4);
  transition: color var(--t-fast);
}
.faq-q:hover { color: var(--clr-primary); }

.faq-icon {
  flex-shrink: 0;
  transition: transform var(--t-med);
}
.faq-q[aria-expanded="true"] .faq-icon {
  transform: rotate(180deg);
}
.faq-q[aria-expanded="true"] { color: var(--clr-primary); }

.faq-a {
  padding-bottom: var(--sp-5);
}
.faq-a p {
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--clr-text-muted);
}

/* ---- Live indicator ---- */
.live-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--clr-primary);
  margin-right: var(--sp-1);
  animation: live-pulse 1.5s infinite;
}

@keyframes live-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(1.3); }
}
