/**
 * Pika Vibe — Component Styles
 *
 * These styles are always enqueued by the plugin (pika-vibe-components handle).
 * They power the built-in block templates using a pure CSS modifier-class system.
 *
 * HOW LAYOUTS WORK
 * ─────────────────
 * The features-grid template adds one class to the <section>:
 *   pika-fg--{card_layout}
 *
 * CSS modifier classes drive ALL layout behaviour:
 *   .pika-fg--default   → intro panel left  +  value-card list right
 *   .pika-fg--grid      → centered header   +  full-width card grid
 *   .pika-fg--media-top → centered header   +  image-on-top card grid
 *
 * Adding a NEW layout variant = add a new CSS block below.
 * Zero PHP template changes needed.
 *
 * The --pika-fg-cols CSS custom property (set inline by the template via the
 * `columns` field) controls how many columns the grid has.
 *
 * @package pika-vibe
 */

/* ═══════════════════════════════════════════════════════════════
 * BASE TOKENS (fallback to WP theme vars if available)
 * ═══════════════════════════════════════════════════════════════ */
.pika-fg {
  --_fg-primary:     var(--color-primary,     #4f46e5);
  --_fg-surface:     var(--color-surface,     #ffffff);
  --_fg-surface-alt: var(--color-surface-alt, #f6f7fb);
  --_fg-text:        var(--color-text,        #111827);
  --_fg-text-muted:  var(--color-text-muted,  #6b7280);
  --_fg-radius:      var(--radius-lg,         1.5rem);
  --_fg-shadow:      var(--shadow-soft,       0 24px 60px rgba(15,23,42,.08));
  --_fg-cols:        var(--pika-fg-cols, 3);

  padding: 5rem 0;
  background: var(--_fg-surface-alt);
}


/* ═══════════════════════════════════════════════════════════════
 * SHARED — header (tag / heading / subheading)
 * ═══════════════════════════════════════════════════════════════ */
.pika-fg__tag {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--_fg-primary);
  margin-bottom: .55rem;
}
.pika-fg__heading {
  font-size: clamp(1.55rem, 2.4vw, 2.1rem);
  font-weight: 800;
  color: var(--_fg-text);
  line-height: 1.2;
  margin: 0 0 .7rem;
}
.pika-fg__subheading {
  font-size: .97rem;
  line-height: 1.7;
  color: var(--_fg-text-muted);
  margin: 0;
}


/* ═══════════════════════════════════════════════════════════════
 * LAYOUT: default
 * Intro panel on the LEFT  ·  Value-card list on the RIGHT
 * ═══════════════════════════════════════════════════════════════ */
.pika-fg--default .pika-fg__wrapper {
  display: grid;
  grid-template-columns: 5fr 8fr;
  gap: clamp(1.5rem, 3vw, 3rem);
  align-items: start;
}

/* Header becomes a sticky intro panel card */
.pika-fg--default .pika-fg__header {
  position: sticky;
  top: 6rem;
  padding: clamp(1.4rem, 2.5vw, 2.4rem);
  border-radius: var(--_fg-radius);
  background: var(--_fg-surface);
  border: 1px solid rgba(0,0,0,.07);
  box-shadow: var(--_fg-shadow);
}

/* Cards: vertical stacked list */
.pika-fg--default .pika-fg__cards {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.pika-fg--default .pika-fg__card {
  display: flex;
  align-items: flex-start;
  gap: 1.2rem;
  padding: 1.6rem 1.8rem;
  border-radius: var(--_fg-radius);
  background: var(--_fg-surface);
  border: 1px solid rgba(0,0,0,.07);
  box-shadow: var(--_fg-shadow);
  transition: transform .3s ease, box-shadow .3s ease;
}
.pika-fg--default .pika-fg__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 50px rgba(15,23,42,.12);
}
/* Number badge as left accent */
.pika-fg--default .pika-fg__card-num {
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .14em;
  color: var(--_fg-primary);
  flex-shrink: 0;
  padding-top: .18em;
  min-width: 2rem;
}
/* Images hidden in default layout */
.pika-fg--default .pika-fg__card-media { display: none; }


/* ═══════════════════════════════════════════════════════════════
 * LAYOUT: grid
 * Centered header  ·  Full-width card grid (icon + text)
 * ═══════════════════════════════════════════════════════════════ */
.pika-fg--grid .pika-fg__wrapper { display: block; }

.pika-fg--grid .pika-fg__header {
  max-width: 44rem;
  margin: 0 auto 3rem;
  text-align: center;
}
.pika-fg--grid .pika-fg__cards {
  display: grid;
  grid-template-columns: repeat(var(--_fg-cols), 1fr);
  gap: 1.5rem;
}
.pika-fg--grid .pika-fg__card {
  padding: 2rem;
  border-radius: var(--_fg-radius);
  background: var(--_fg-surface);
  border: 1px solid rgba(0,0,0,.07);
  box-shadow: var(--_fg-shadow);
  transition: transform .3s ease, box-shadow .3s ease;
}
.pika-fg--grid .pika-fg__card:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 55px rgba(15,23,42,.13);
}
.pika-fg--grid .pika-fg__card-num {
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .14em;
  color: var(--_fg-primary);
  margin-bottom: .9rem;
}
/* Images hidden in grid layout — icon only */
.pika-fg--grid .pika-fg__card-media { display: none; }


/* ═══════════════════════════════════════════════════════════════
 * LAYOUT: media-top
 * Centered header  ·  Image-on-top cards
 * ═══════════════════════════════════════════════════════════════ */
.pika-fg--media-top .pika-fg__wrapper { display: block; }

.pika-fg--media-top .pika-fg__header {
  max-width: 44rem;
  margin: 0 auto 3rem;
  text-align: center;
}
.pika-fg--media-top .pika-fg__cards {
  display: grid;
  grid-template-columns: repeat(var(--_fg-cols), 1fr);
  gap: 1.5rem;
}
.pika-fg--media-top .pika-fg__card {
  display: flex;
  flex-direction: column;
  border-radius: var(--_fg-radius);
  background: var(--_fg-surface);
  border: 1px solid rgba(0,0,0,.07);
  box-shadow: var(--_fg-shadow);
  overflow: hidden;
  transition: transform .3s ease, box-shadow .3s ease;
}
.pika-fg--media-top .pika-fg__card:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 55px rgba(15,23,42,.13);
}
/* Image area */
.pika-fg--media-top .pika-fg__card-media {
  display: block;
  position: relative;
  width: 100%;
  height: 14rem;
  overflow: hidden;
  background: var(--_fg-primary);
  flex-shrink: 0;
}
.pika-fg--media-top .pika-fg__card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
.pika-fg--media-top .pika-fg__card:hover .pika-fg__card-img {
  transform: scale(1.05);
}
.pika-fg--media-top .pika-fg__card-icon {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: rgba(255,255,255,.45);
}
.pika-fg--media-top .pika-fg__card-icon svg {
  width: 3rem;
  height: 3rem;
}
/* Card content below image */
.pika-fg--media-top .pika-fg__card-content {
  padding: 1.6rem 1.8rem 2rem;
  flex: 1;
}
/* Number hidden in media-top — not needed visually */
.pika-fg--media-top .pika-fg__card-num { display: none; }


/* ═══════════════════════════════════════════════════════════════
 * VARIANT: media-left
 * Centered header + n-column grid of horizontal cards (image left, text right).
 * Column count driven by --pika-fg-cols (set inline by the template).
 * ═══════════════════════════════════════════════════════════════ */
.pika-fg--media-left .pika-fg__wrapper { display: block; }

.pika-fg--media-left .pika-fg__header {
  text-align: center;
  margin-bottom: var(--space-2xl, 3.5rem);
}

.pika-fg--media-left .pika-fg__cards {
  display: grid;
  grid-template-columns: repeat(var(--_fg-cols), 1fr);
  gap: var(--space-xl, 2rem);
}

.pika-fg--media-left .pika-fg__card {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 0;
  background: var(--color-surface, #fff);
  border-radius: var(--radius-lg, 0.75rem);
  border: 1px solid var(--color-border, rgba(0,0,0,.08));
  overflow: hidden;
  transition: box-shadow .22s ease, transform .22s ease;
}

.pika-fg--media-left .pika-fg__card:hover {
  box-shadow: 0 8px 28px rgba(0,0,0,.10);
  transform: translateY(-3px);
}

.pika-fg--media-left .pika-fg__card-media {
  display: block;
  flex: 0 0 44%;
  max-width: 44%;
  min-height: 13rem;
  overflow: hidden;
}

.pika-fg--media-left .pika-fg__card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}

.pika-fg--media-left .pika-fg__card:hover .pika-fg__card-img {
  transform: scale(1.04);
}

.pika-fg--media-left .pika-fg__card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 10rem;
  background: var(--color-surface-alt, #f5f5f5);
  color: var(--color-accent, currentColor);
}

.pika-fg--media-left .pika-fg__card-icon svg {
  width: 2.5rem;
  height: 2.5rem;
}

.pika-fg--media-left .pika-fg__card-content {
  flex: 1;
  min-width: 0;
  padding: var(--space-lg, 1.5rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-sm, 0.5rem);
}

.pika-fg--media-left .pika-fg__card-num { display: none; }


/* ═══════════════════════════════════════════════════════════════
 * SHARED — card text content
 * ═══════════════════════════════════════════════════════════════ */
.pika-fg__card-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--_fg-text);
  margin: 0 0 .45rem;
  text-transform: uppercase;
  letter-spacing: .02em;
}
.pika-fg__card-text {
  font-size: .94rem;
  line-height: 1.68;
  color: var(--_fg-text-muted);
  margin: 0;
}
/* default layout overrides for card content (no top padding — it's inline) */
.pika-fg--default .pika-fg__card-content { flex: 1; }
.pika-fg--default .pika-fg__card-title { text-transform: none; }


/* ═══════════════════════════════════════════════════════════════
 * RESPONSIVE
 * ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1199.98px) {
  .pika-fg--default .pika-fg__wrapper {
    grid-template-columns: 1fr 1.6fr;
  }
}

@media (max-width: 991.98px) {
  .pika-fg--default .pika-fg__wrapper {
    grid-template-columns: 1fr;
  }
  .pika-fg--default .pika-fg__header {
    position: static;
  }
  .pika-fg--grid .pika-fg__cards,
  .pika-fg--media-top .pika-fg__cards {
    grid-template-columns: repeat(min(var(--_fg-cols), 2), 1fr);
  }
  .pika-fg--media-left .pika-fg__cards {
    grid-template-columns: 1fr;
  }
  .pika-fg--media-left .pika-fg__card {
    flex-direction: row;
  }
  .pika-fg--media-left .pika-fg__card-media {
    flex: 0 0 40%;
    max-width: 40%;
  }
}

@media (max-width: 767.98px) {
  .pika-fg { padding: 3.5rem 0; }

  .pika-fg--default .pika-fg__header,
  .pika-fg--default .pika-fg__card {
    padding: 1.2rem 1.4rem;
    border-radius: 1.2rem;
  }
  .pika-fg--grid .pika-fg__cards,
  .pika-fg--media-top .pika-fg__cards {
    grid-template-columns: 1fr;
  }
  .pika-fg--media-top .pika-fg__card-media {
    height: 11rem;
  }
  .pika-fg--media-top .pika-fg__card-content {
    padding: 1.2rem 1.4rem;
  }
  .pika-fg--media-left .pika-fg__card {
    flex-direction: column;
  }
  .pika-fg--media-left .pika-fg__card-media {
    flex: none;
    max-width: 100%;
    min-height: 11rem;
  }
  .pika-fg--media-left .pika-fg__card-content {
    padding: 1.2rem 1.4rem;
  }
}

/* ═══════════════════════════════════════════════════════════════
 * SCROLL ENTRANCE ANIMATIONS
 *
 * Triggered by data-pika-animate="{preset}" on the section element.
 * pika-vibe-components.js adds .pika-animated via IntersectionObserver.
 *
 * .js-ready guard prevents invisible elements when JS hasn't run yet.
 * data-pika-no-animate on <body> disables all animations (editor canvas).
 * prefers-reduced-motion: JS exits early, so transitions never fire.
 * ═══════════════════════════════════════════════════════════════ */

/* Editor canvas: always show elements regardless of animation state */
[data-pika-no-animate] [data-pika-animate] {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* Initial hidden state — only when JS is ready AND not in editor */
.js-ready [data-pika-animate]:not(.pika-animated):not([data-pika-no-animate] *) {
  opacity: 0;
  transition: none;
}

/* fade-up: slide up from slightly below + fade in */
.js-ready [data-pika-animate="fade-up"]:not(.pika-animated):not([data-pika-no-animate] *) {
  transform: translateY(1.75rem);
}
.js-ready [data-pika-animate="fade-up"].pika-animated {
  opacity: 1;
  transform: none;
  transition: opacity 0.55s ease, transform 0.55s ease;
}

/* fade-in: fade in only, no movement */
.js-ready [data-pika-animate="fade-in"].pika-animated {
  opacity: 1;
  transition: opacity 0.6s ease;
}

/* slide-up: more pronounced upward movement */
.js-ready [data-pika-animate="slide-up"]:not(.pika-animated):not([data-pika-no-animate] *) {
  transform: translateY(3rem);
}
.js-ready [data-pika-animate="slide-up"].pika-animated {
  opacity: 1;
  transform: none;
  transition: opacity 0.5s ease, transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

/* scale-in: subtle scale up + fade in */
.js-ready [data-pika-animate="scale-in"]:not(.pika-animated):not([data-pika-no-animate] *) {
  transform: scale(0.96);
}
.js-ready [data-pika-animate="scale-in"].pika-animated {
  opacity: 1;
  transform: none;
  transition: opacity 0.5s ease, transform 0.5s ease;
}
