/* =========================================================================
   Beziworld React Theme — interactivity layer.
   Presentation for the Interactivity API modules: mini-cart drawer,
   quick-view modal, loading/busy states, the sticky add-to-cart bar, and the
   screen-reader-only helper used by aria-live regions. This is the last
   author layer before utilities, so it owns the chrome that overlays the
   page. Tokens come from base.css; this layer never redefines them.

   Open/closed state is driven by the modules through data-wp-class--is-open
   directives, so styling keys off the .is-open class rather than inline
   styles. Motion is suppressed under prefers-reduced-motion.
   ========================================================================= */
@layer interactivity {

  /* =========================================================================
     Mini-cart drawer (store: beziworld/miniCart)
     Right-anchored slide-in panel with a scrim, reusing the drawer vibe from
     the base layer (.drawer) while staying a distinct, cart-specific surface.
     ========================================================================= */
  .beziworld-mini-cart { display: contents; }

  .mini-cart__scrim {
    position: fixed; inset: 0; z-index: 100;
    background: oklch(0.2 0.03 222 / 0.5);
    opacity: 0; pointer-events: none;
    transition: opacity 0.28s ease;
  }
  .mini-cart__scrim.is-open { opacity: 1; pointer-events: auto; }

  .mini-cart__drawer {
    position: fixed; top: 0; right: 0; bottom: 0; z-index: 110;
    width: min(92vw, 420px);
    background: var(--paper); border-left: 1px solid var(--line);
    box-shadow: var(--shadow-md);
    display: flex; flex-direction: column;
    transform: translateX(100%);
    visibility: hidden;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s linear 0.3s;
  }
  .mini-cart__drawer.is-open { transform: translateX(0); visibility: visible; transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s; }

  .mini-cart__head {
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--line);
  }
  .mini-cart__title { font-family: var(--font-head); font-size: 1.25rem; font-weight: 600; }
  .mini-cart__close {
    width: 40px; height: 40px; flex: none; border-radius: var(--radius);
    display: grid; place-items: center; color: var(--ink-soft);
    border: 1px solid transparent; background: none; cursor: pointer;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
  }
  .mini-cart__close:hover { background: var(--paper-2); color: var(--ink); border-color: var(--line); }
  .mini-cart__close svg { width: 20px; height: 20px; }

  .mini-cart__body { flex: 1; overflow-y: auto; padding: 0.75rem 1.5rem; }
  .mini-cart__empty { text-align: center; color: var(--ink-soft); padding-block: clamp(2rem, 8vh, 4rem); }

  .mini-cart__item {
    display: grid; grid-template-columns: 64px 1fr auto; gap: 1rem;
    align-items: center; padding: 1rem 0; border-bottom: 1px solid var(--line);
  }
  .mini-cart__item .ph { aspect-ratio: 1; border-radius: var(--radius); }
  .mini-cart__item .ph::after { display: none; }
  .mini-cart__item-name { font-weight: 500; font-size: 0.95rem; }
  .mini-cart__item-meta { font-family: var(--font-mono); font-size: 0.74rem; color: var(--ink-faint); margin-top: 0.2rem; }
  .mini-cart__item-price { font-family: var(--font-head); font-weight: 600; white-space: nowrap; }

  .mini-cart__foot { border-top: 1px solid var(--line); padding: 1.25rem 1.5rem; background: var(--paper-2); }
  .mini-cart__subtotal {
    display: flex; align-items: baseline; justify-content: space-between; gap: 1rem;
    margin-bottom: 1rem;
  }
  .mini-cart__subtotal .label { color: var(--ink-soft); font-size: 0.95rem; }
  .mini-cart__subtotal .value { font-family: var(--font-head); font-size: 1.3rem; font-weight: 600; }
  .mini-cart__actions { display: grid; gap: 0.6rem; }
  .mini-cart__actions .btn { justify-content: center; }

  /* Header trigger and its live count badge. */
  .beziworld-mini-cart__count {
    position: absolute; top: 2px; right: 2px; min-width: 17px; height: 17px; padding: 0 4px;
    background: var(--accent); color: var(--accent-ink); border-radius: 999px;
    font-family: var(--font-mono); font-size: 0.62rem; font-weight: 700;
    display: grid; place-items: center; line-height: 1;
  }
  .beziworld-mini-cart__count[hidden] { display: none; }

  /* =========================================================================
     Quick-view modal (store: beziworld/quickView)
     Centered dialog over a full-viewport backdrop. Hidden until is-open.
     ========================================================================= */
  .beziworld-quick-view { display: contents; }

  .quick-view__backdrop {
    position: fixed; inset: 0; z-index: 120;
    display: grid; place-items: center;
    padding: clamp(1rem, 4vw, 3rem);
    background: oklch(0.2 0.03 222 / 0.55);
    opacity: 0; pointer-events: none;
    visibility: hidden;
    transition: opacity 0.24s ease, visibility 0s linear 0.24s;
  }
  .quick-view__backdrop.is-open { opacity: 1; pointer-events: auto; visibility: visible; transition: opacity 0.24s ease, visibility 0s; }

  .quick-view__dialog {
    position: relative;
    width: min(100%, 920px); max-height: min(90svh, 720px);
    overflow-y: auto;
    background: var(--paper); border: 1px solid var(--line);
    border-radius: var(--radius-lg); box-shadow: var(--shadow-md);
    padding: clamp(1.5rem, 4vw, 2.5rem);
    transform: translateY(16px) scale(0.98);
    transition: transform 0.24s cubic-bezier(0.2, 0, 0.1, 1);
  }
  .quick-view__backdrop.is-open .quick-view__dialog { transform: none; }
  .quick-view__dialog:focus-visible { outline: 2.5px solid var(--accent); outline-offset: 3px; }

  .quick-view__close {
    position: absolute; top: 0.9rem; right: 0.9rem; z-index: 2;
    width: 40px; height: 40px; border-radius: var(--radius);
    display: grid; place-items: center; color: var(--ink-soft);
    border: 1px solid var(--line); background: var(--paper); cursor: pointer;
    transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
  }
  .quick-view__close:hover { background: var(--paper-2); color: var(--ink); border-color: var(--ink-faint); }
  .quick-view__close svg { width: 20px; height: 20px; }

  /* Quick-view body layout (rendered server-side by the REST endpoint). */
  .quick-view__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 2.5rem); align-items: start; }
  .quick-view__media { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line); background: var(--paper-3); }
  .quick-view__media img { width: 100%; height: auto; aspect-ratio: 4 / 5; object-fit: cover; }
  .quick-view__info { display: flex; flex-direction: column; gap: 0.9rem; }
  .quick-view__title { font-family: var(--font-head); font-size: clamp(1.5rem, 3vw, 2.1rem); font-weight: 500; }
  .quick-view__excerpt { color: var(--ink-soft); }
  .quick-view__error { color: var(--ink-soft); }
  .quick-view__trigger { margin-top: 0.5rem; cursor: pointer; }
  @media (max-width: 720px) {
    .quick-view__inner { grid-template-columns: 1fr; }
    .quick-view__media img { aspect-ratio: 16 / 10; }
  }

  /* =========================================================================
     Loading / busy states
     Applied via [aria-busy="true"] on any container and the .is-loading
     utility class for elements that own the spinner directly.
     ========================================================================= */
  @keyframes beziworld-spin { to { transform: rotate(360deg); } }

  [aria-busy="true"] { position: relative; cursor: progress; }
  [aria-busy="true"]::after {
    content: ""; position: absolute; inset: 0; z-index: 5;
    margin: auto; width: 28px; height: 28px;
    border-radius: 50%;
    border: 2.5px solid var(--line-strong);
    border-top-color: var(--accent);
    animation: beziworld-spin 0.7s linear infinite;
  }

  .is-loading { pointer-events: none; opacity: 0.6; transition: opacity 0.16s ease; }

  /* Inline spinner usable inside buttons and standalone regions. */
  .beziworld-spinner {
    display: inline-block; width: 1.1em; height: 1.1em; vertical-align: -0.15em;
    border-radius: 50%;
    border: 2px solid color-mix(in oklab, currentColor 30%, transparent);
    border-top-color: currentColor;
    animation: beziworld-spin 0.7s linear infinite;
  }

  /* =========================================================================
     Sticky add-to-cart bar (store: beziworld/stickyAtc)
     Bottom-anchored bar, hidden by default, slides up when activated.
     ========================================================================= */
  .beziworld-sticky-atc {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 70;
    background: color-mix(in oklab, var(--paper) 92%, transparent);
    backdrop-filter: saturate(1.4) blur(14px);
    border-top: 1px solid var(--line);
    box-shadow: 0 -6px 24px oklch(0 0 0 / 0.08);
    transform: translateY(100%);
    transition: transform 0.3s cubic-bezier(0.2, 0, 0.1, 1);
  }
  .beziworld-sticky-atc.is-visible { transform: translateY(0); }

  .beziworld-sticky-atc__inner {
    display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
    padding-block: 0.85rem;
  }
  .beziworld-sticky-atc__info { display: flex; align-items: baseline; gap: 0.75rem; margin-right: auto; min-width: 0; }
  .beziworld-sticky-atc__name { font-family: var(--font-head); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .beziworld-sticky-atc__price { color: var(--accent); font-family: var(--font-head); font-weight: 600; white-space: nowrap; }
  .beziworld-sticky-atc__actions { display: flex; align-items: center; gap: 0.6rem; }
  .beziworld-sticky-atc__actions .btn-primary { justify-content: center; }

  @media (max-width: 560px) {
    .beziworld-sticky-atc__info { width: 100%; }
  }

  /* =========================================================================
     Screen-reader-only helper
     For visually hidden aria-live regions announcing cart/quick-view updates.
     ========================================================================= */
  .screen-reader-text {
    position: absolute !important;
    width: 1px; height: 1px;
    margin: -1px; padding: 0;
    overflow: hidden; clip: rect(0, 0, 0, 0); clip-path: inset(50%);
    border: 0; white-space: nowrap;
    word-wrap: normal !important;
  }
  .screen-reader-text:focus {
    position: fixed !important; top: 1rem; left: 1rem; z-index: 200;
    width: auto; height: auto; margin: 0; padding: 0.6rem 1rem;
    clip: auto; clip-path: none; white-space: normal;
    background: var(--accent); color: var(--accent-ink);
    border-radius: var(--radius); font-weight: 600;
  }

  /* =========================================================================
     Reduced motion
     ========================================================================= */
  @media (prefers-reduced-motion: reduce) {
    .mini-cart__scrim,
    .mini-cart__drawer,
    .quick-view__backdrop,
    .quick-view__dialog,
    .beziworld-sticky-atc {
      transition: none;
    }
    .quick-view__dialog { transform: none; }
    [aria-busy="true"]::after,
    .beziworld-spinner {
      animation-duration: 1.4s;
    }
  }
}
