/* ================================================
   Brand Accordion – Elementor Widget Styles
   ================================================ */

.brand-accordion-widget {
  font-family: var(--font-sans, 'Segoe UI', system-ui, sans-serif);
  --bra-accent: #00cfff;               /* FIX #1: was #00aeef; aligned to PHP title_color default & Figma cyan */
  --bra-accent-even: #ff4d8d;          /* FIX #2: explicit even-item accent variable */
  --bra-anim-speed: 450ms;
  --bra-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --bra-overlay-start: rgba(10, 20, 32, 0.96);
  --bra-overlay-end: rgba(10, 20, 32, 0);
  --bra-overlay-stop: 70%;
}

.brand-accordion-widget *,
.brand-accordion-widget *::before,
.brand-accordion-widget *::after {
  box-sizing: border-box;
}

/* ── Outer wrap ── */
.brand-accordion-widget .bra-wrap {
  width: 100%;
  display: block;
}

/* ═══════════════════════════════════════════════
   ITEM (card)
   ═══════════════════════════════════════════════ */
.brand-accordion-widget .bra-item {
  position: relative;
  background-color: #0a0a0a;
  border-radius: 18px;
/*   padding: 0 25px 0 0; */
  overflow: hidden;
  transition:
    background-color var(--bra-anim-speed) var(--bra-ease),
    min-height var(--bra-anim-speed) var(--bra-ease),
    box-shadow var(--bra-anim-speed) var(--bra-ease),
    transform var(--bra-anim-speed) var(--bra-ease),
    padding var(--bra-anim-speed) var(--bra-ease);
}

/* Inject the per-item bg image only when the card is open. */
.brand-accordion-widget .bra-item.is-open {
  background-image: var(--bra-bg-image, none);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center right;
  padding: 0;
  border-color: transparent;           /* FIX #3: remove card border in expanded state */
}

.brand-accordion-widget.has-hover .bra-item:not(.is-open):hover {
  transform: translateY(-1px);
}

/* ═══════════════════════════════════════════════
   HEADER (closed-state row — hidden when open)
   ═══════════════════════════════════════════════ */
.brand-accordion-widget .bra-header {
/*   appearance: none; */
  display: flex;
  align-items: center;
  gap: 22px;
  width: 100%;
  padding: 0;
  margin: 0;
/*   background: transparent;
  border: 0; */
  color: inherit;
  font: inherit;
  text-align: left;
/*   cursor: pointer; */
  position: relative;
  z-index: 2;
  overflow: hidden;
  transition:
    max-height var(--bra-anim-speed) var(--bra-ease),
    opacity var(--bra-anim-speed) var(--bra-ease);
}

/* .brand-accordion-widget .bra-expand {
  appearance: none;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  padding: 0;
  margin: 0;
  background: transparent;
  border: 0;
  color: inherit;
  font: inherit;
  text-align: center;
  cursor: pointer;
}



.brand-accordion-widget .bra-header:focus-visible {
  outline: 2px solid var(--bra-accent);
  outline-offset: 3px;
  border-radius: 12px;
}
 */


.brand-accordion-widget .bra-expand {
appearance: none;
display: inline-flex;
flex-direction: column;
align-items: center;
justify-content: center;
flex: 0 0 auto;
padding: 0;
margin: 0;
background: transparent;
border: 0;
color: inherit;
font: inherit;
text-align: center;
cursor: pointer;
outline: none;
-webkit-tap-highlight-color: transparent;
}

.brand-accordion-widget .bra-expand:focus,
.brand-accordion-widget .bra-expand:focus-visible,
.brand-accordion-widget .bra-expand:active {
outline: none;
box-shadow: none;
}

.brand-accordion-widget .bra-expand .bra-toggle {
outline: none;
}

/* When item is open: collapse header so panel fills the card */
.brand-accordion-widget .bra-item.is-open .bra-header {
  max-height: 0;
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}

/* ── Thumbnail (collapsed image, fades to BG via gradient) ── */
.brand-accordion-widget .bra-thumb {
  position: relative;
  flex: 0 0 150px;
  width: 150px;
  height: 80px;
  border-radius: 12px;
  overflow: hidden;
  background: #111;
}

.brand-accordion-widget .bra-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--bra-anim-speed) var(--bra-ease);
}

/* Right-side gradient overlay that fades thumb into card */
.brand-accordion-widget .bra-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, #0a0a0a 100%);
  pointer-events: none;
}

.brand-accordion-widget.has-hover .bra-item:not(.is-open):hover .bra-thumb img {
  transform: scale(1.04);
}

/* ── Summary block (title + subtitle) ── */
.brand-accordion-widget .bra-summary {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  min-width: 0;
  padding-right: 12px;
}

/* FIX #4: Title — allow 2-line wrap to match Figma (was white-space:nowrap, text-overflow:ellipsis).
   Figma shows multi-line titles (e.g. "What can a brand agency / do for my business?").
   Use line-clamp at 2 to cap runaway titles while still allowing the expected wrap. */
.brand-accordion-widget .bra-title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: var(--bra-accent);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.01em;
	text-wrap: auto;
}

/* FIX #5: Even items use the pink accent as base CSS fallback (without Elementor overrides).
   Matches Figma alternating cyan/pink colour scheme. */
.brand-accordion-widget .bra-item:nth-child(even) .bra-title,
.brand-accordion-widget .bra-item:nth-child(even) .bra-content-title {
  color: var(--bra-accent-even);
}

/* Multi-line clamp + ellipsis for subtitle */
.brand-accordion-widget .bra-subtitle {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  color: rgba(255, 255, 255, 0.75);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.4;
  word-break: break-word;
  min-width: 0;
}

/* ── Toggle wrapper (icon + optional label) ── */
.brand-accordion-widget .bra-toggle-wrap {
  flex: 0 0 auto;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 90px;
  margin-right: 20px;
}

.brand-accordion-widget .bra-toggle {
  width: 90px;
  height: 38px;
  border-radius: 50px;
  background: #00aeef;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: box-shadow var(--bra-anim-speed) var(--bra-ease);
}

.brand-accordion-widget .bra-toggle .bra-icon,
.brand-accordion-widget .bra-close .bra-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 1;
}

.brand-accordion-widget .bra-toggle .bra-icon svg,
.brand-accordion-widget .bra-close .bra-icon svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

.brand-accordion-widget .bra-toggle-label {
  font-size: 10px;
  line-height: 1.2;
  text-align: center;
  color: rgba(255, 255, 255, 0.7);
  white-space: nowrap;
}

.brand-accordion-widget.has-hover .bra-expand:hover .bra-toggle {
  box-shadow: 0 0 0 4px rgba(0, 174, 239, 0.18);
}

/* ═══════════════════════════════════════════════
   PANEL (expanded content + overlay gradient)
   ═══════════════════════════════════════════════ */
.brand-accordion-widget .bra-panel {
  position: relative;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition:
    max-height var(--bra-anim-speed) var(--bra-ease),
    opacity var(--bra-anim-speed) var(--bra-ease);
}

.brand-accordion-widget .bra-item.is-open .bra-panel {
  opacity: 1;
}

/* Dark-to-transparent overlay on top of the bg image for readability */
.brand-accordion-widget .bra-item.is-open .bra-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg,
      var(--bra-overlay-start) 0%,
      var(--bra-overlay-end) var(--bra-overlay-stop, 70%));
  z-index: 1;
}

/* ── Close button wrapper (top-right of expanded card) ── */
.brand-accordion-widget .bra-close-wrap {
  position: absolute;
  top: 24px;
  right: 24px;
  z-index: 4;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  pointer-events: none;
}

/* .brand-accordion-widget .bra-close {
  pointer-events: auto;
  width: 90px;
  height: 38px;
  padding: 0;
  border: 0;
  border-radius: 50px;
  background: #ffffff;
  color: #00aeef;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition:
    background var(--bra-anim-speed) var(--bra-ease),
    transform var(--bra-anim-speed) var(--bra-ease),
    box-shadow var(--bra-anim-speed) var(--bra-ease);
}

.brand-accordion-widget .bra-close:focus-visible {
  outline: 2px solid var(--bra-accent);
  outline-offset: 3px;
} */

.brand-accordion-widget .bra-close {
pointer-events: auto;
width: 90px;
height: 38px;
padding: 0;
border: 0;
border-radius: 50px;
background: #ffffff;
color: #00aeef;
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
outline: none;
-webkit-tap-highlight-color: transparent;
transition:
background var(--bra-anim-speed) var(--bra-ease),
transform var(--bra-anim-speed) var(--bra-ease),
box-shadow var(--bra-anim-speed) var(--bra-ease);
}

.brand-accordion-widget .bra-close:focus,
.brand-accordion-widget .bra-close:focus-visible,
.brand-accordion-widget .bra-close:active {
outline: none;
box-shadow: none;
}

.brand-accordion-widget.has-hover .bra-close:hover {
  transform: scale(1.05);
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.18);
}

.brand-accordion-widget .bra-toggle-label-close {
  font-size: 10px;
  line-height: 1.2;
  text-align: center;
  color: rgba(255, 255, 255, 0.85);
  white-space: nowrap;
  pointer-events: none;               /* FIX #6: labels in close-wrap are display only */
}

/* ── Panel content area (sits on the left over the overlay) ── */
.brand-accordion-widget .bra-panel-content {
  position: relative;
  z-index: 2;
  max-width: 55%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 44px;
  opacity: 0;
  transform: translateY(6px);
  transition:
    opacity var(--bra-anim-speed) var(--bra-ease) 80ms,
    transform var(--bra-anim-speed) var(--bra-ease) 80ms;
}

.brand-accordion-widget .bra-item.is-open .bra-panel-content {
  opacity: 1;
  transform: translateY(0);
}

.brand-accordion-widget .bra-content-title {
  color: var(--bra-accent);
  font-size: 32px;
  font-weight: 800;
  line-height: 1.1;
  margin: 0;
  letter-spacing: -0.01em;
}

.brand-accordion-widget .bra-description {
  color: rgba(255, 255, 255, 0.85);
  font-size: 14px;
  line-height: 1.65;
}

.brand-accordion-widget .bra-description p {
  margin: 0 0 0.8em;
}

.brand-accordion-widget .bra-description p:last-child {
  margin-bottom: 0;
}

/* ── CTA Button ── */
.brand-accordion-widget .bra-button {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 22px;
  background: #00aeef;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  border-radius: 30px;
  text-decoration: none;
  transition:
    background var(--bra-anim-speed) var(--bra-ease),
    color var(--bra-anim-speed) var(--bra-ease),
    transform var(--bra-anim-speed) var(--bra-ease);
}

.brand-accordion-widget .bra-button:hover {
  background: #ff4d8d;
  color: #fff;
  transform: translateY(-1px);
}

/* ═══════════════════════════════════════════════
   FIX #7: ICON ANIMATION (has-icon-anim)
   The PHP outputs this class but the original CSS
   had no rules for it — icons never animated.
   Now: close icon spins in when panel opens;
   toggle icon has a snappy pop on click.
   ═══════════════════════════════════════════════ */
@keyframes braIconSpinIn {
  from {
    transform: rotate(-90deg) scale(0.5);
    opacity: 0;
  }
  to {
    transform: rotate(0deg) scale(1);
    opacity: 1;
  }
}

@keyframes braIconPopIn {
  0%   { transform: scale(1); }
  40%  { transform: scale(0.8); }
  100% { transform: scale(1); }
}

/* Close icon animates in when the panel opens */
.brand-accordion-widget.has-icon-anim .bra-item.is-open .bra-close .bra-icon {
  animation: braIconSpinIn var(--bra-anim-speed) var(--bra-ease) both;
}

/* Toggle icon gets a small pop on every state change (re-triggers via JS class toggling) */
.brand-accordion-widget.has-icon-anim .bra-toggle .bra-icon {
  transition:
    transform var(--bra-anim-speed) var(--bra-ease),
    opacity var(--bra-anim-speed) var(--bra-ease);
}

/* Smooth icon appearance on open */
.brand-accordion-widget.has-icon-anim .bra-item.is-open .bra-close {
  animation: braIconPopIn calc(var(--bra-anim-speed) * 0.6) var(--bra-ease) both;
}

/* ═══════════════════════════════════════════════
   ANIMATIONS DISABLED — kill remaining transitions
   ═══════════════════════════════════════════════ */
.brand-accordion-widget:not(.has-anim) .bra-item,
.brand-accordion-widget:not(.has-anim) .bra-header,
.brand-accordion-widget:not(.has-anim) .bra-expand,
.brand-accordion-widget:not(.has-anim) .bra-thumb img,
.brand-accordion-widget:not(.has-anim) .bra-toggle,
.brand-accordion-widget:not(.has-anim) .bra-close,
.brand-accordion-widget:not(.has-anim) .bra-panel,
.brand-accordion-widget:not(.has-anim) .bra-panel-content,
.brand-accordion-widget:not(.has-anim) .bra-button {
  transition: none !important;
  animation: none !important;          /* FIX #8: also kill keyframe animations */
}

/* ═══════════════════════════════════════════════
   PREFERS-REDUCED-MOTION
   ═══════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {

  .brand-accordion-widget *,
  .brand-accordion-widget *::before,
  .brand-accordion-widget *::after {
    transition-duration: 0.001ms !important;
    animation-duration: 0.001ms !important;
  }
}

/* ═══════════════════════════════════════════════
   TABLET ( ≤ 1024px )
   ═══════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .brand-accordion-widget .bra-title {
    font-size: 18px;
  }

  .brand-accordion-widget .bra-content-title {
    font-size: 26px;
  }

  .brand-accordion-widget .bra-subtitle {
    font-size: 12px;
  }

  .brand-accordion-widget .bra-panel-content {
    padding: 32px;
    max-width: 60%;
  }
}

/* ═══════════════════════════════════════════════
   MOBILE ( ≤ 767px )
   FIX #9: Consolidated all mobile .bra-panel-content
   rules into one declaration. Previously two
   separate rules existed — the second override
   (`70px 44px 44px 44px !important`) was too wide
   for small screens (44px side padding on mobile).
   Corrected to 16px side padding.
   ═══════════════════════════════════════════════ */
@media (max-width: 767px) {
  .brand-accordion-widget .bra-item {
    padding: 10px 0 10px 14px;
    border-radius: 14px;
  }

  /* Hide collapsed thumbnail on mobile */
  .brand-accordion-widget .bra-thumb {
    display: none !important;
  }

  /* Keep title + toggle on one row */
  .brand-accordion-widget .bra-header {
    gap: 14px;
    flex-wrap: nowrap;
  }

  .brand-accordion-widget .bra-summary {
    padding-right: 8px;
    min-width: 0;
  }

  /* FIX #10: Title on mobile — allow 2-line wrap, slightly smaller size */
  .brand-accordion-widget .bra-title {
    font-size: 15px;
    -webkit-line-clamp: 3;
    line-clamp: 3;
  }

  .brand-accordion-widget .bra-subtitle {
    font-size: 12px;
  }

  .brand-accordion-widget .bra-toggle {
    width: 70px;
    height: 34px;
  }

  .brand-accordion-widget .bra-toggle-wrap {
    min-width: 70px;
    flex: 0 0 auto;
  }

  .brand-accordion-widget .bra-toggle .bra-icon {
    font-size: 14px;
  }

  .brand-accordion-widget .bra-toggle .bra-icon svg {
    width: 14px;
    height: 14px;
  }

  /* FIX #11: Hide toggle labels on mobile to save horizontal space.
     The Figma mobile design omits these labels to prevent overflow. */
  .brand-accordion-widget .bra-toggle-label,
  .brand-accordion-widget .bra-toggle-label-close {
    display: none;
  }

  .brand-accordion-widget .bra-close-wrap {
    top: 12px;
    right: 12px;
  }

  .brand-accordion-widget .bra-close {
    width: 70px;
    height: 34px;
  }

  .brand-accordion-widget .bra-close .bra-icon {
    font-size: 14px;
  }

  .brand-accordion-widget .bra-close .bra-icon svg {
    width: 14px;
    height: 14px;
  }

  /* Expanded card: full-coverage dark overlay for readability on mobile */
  .brand-accordion-widget .bra-item.is-open .bra-panel::before {
    background: linear-gradient(180deg,
        rgba(10, 20, 32, 0.88) 0%,
        rgba(10, 20, 32, 0.78) 100%);
  }

  .brand-accordion-widget .bra-content-title {
    font-size: 22px;
  }

  .brand-accordion-widget .bra-description {
    font-size: 13px;
    line-height: 1.6;
  }

  /* FIX #9 (continued): Single, consolidated rule.
     Replaces the two conflicting declarations from the original CSS:
       Rule 1: padding: 56px 16px 18px  (correct side spacing)
       Rule 2: padding: 70px 44px 44px 44px !important  (wrong — too wide)
     The correct top offset is 56px (enough clearance for close btn at top:12px).
     Side padding stays at 16px for comfortable reading on narrow screens. */
  .brand-accordion-widget .bra-panel-content {
    padding: 75px 16px 18px 16px !important;
    max-width: 100% !important;
    gap: 12px;
    min-height: 0 !important;
  }

  .brand-accordion-widget .bra-button {
    padding: 9px 18px;
    font-size: 12px;
  }

  .brand-accordion-widget .bra-item.is-open {
    padding: 0;
  }
}
