/* ===== Accordion Component ===== */

.accordion {
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  z-index: 10;
}

.accordion-item {
  border-bottom: 1px solid var(--color-border-light);
}

.accordion-item:last-child {
  border-bottom: none;
}

/* Accordion Header/Trigger */
.accordion-header {
  width: 100%;
  padding: var(--spacing-lg) var(--spacing-xl);
  background: var(--color-bg-elevated-2);
  border: 1px solid var(--color-border-light);
  border-bottom: none;
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-md);
  transition: all var(--transition-base);
  font-family: var(--font-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-light);
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

.accordion-header:hover {
  background: var(--color-bg-elevated-3);
  border-color: var(--color-border-medium);
}

.accordion-item.active .accordion-header {
  background: var(--color-primary);
  color: var(--color-text-light);
  border-color: var(--color-primary);
}

/* Accordion Title */
.accordion-title {
  flex: 1;
}

/* Accordion Icon */
.accordion-icon {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  flex-shrink: 0;
}

.accordion-icon-wrapper {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(90deg);
  transition: transform var(--transition-base);
}

.accordion-item.active .accordion-icon-wrapper {
  transform: rotate(180deg);
}

.accordion-icon-text {
  font-size: var(--font-size-sm);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  white-space: nowrap;
  opacity: 0.7;
  transition: opacity var(--transition-base);
}

.accordion-header:hover .accordion-icon-text {
  opacity: 1;
}

.accordion-item.active .accordion-icon-text {
  opacity: 1;
}

/* Default Chevron Icon (CSS only) */
.accordion-icon-default {
  width: 12px;
  height: 12px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-135deg);
}

/* Accordion Content */
.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slower);
}

.accordion-item.active .accordion-content {
  max-height: 1000px; /* Adjust based on content */
  transition: max-height var(--transition-slower);
}

.accordion-body {
  padding: var(--spacing-lg) var(--spacing-xl);
  background: var(--color-bg-elevated-2);
  border: 1px solid var(--color-border-light);
  border-top: none;
  color: var(--color-text-light);
  line-height: var(--line-height-relaxed);
}

/* ===== Accordion Variants ===== */

/* Bordered Accordion */
.accordion-bordered {
  border: 1px solid var(--color-border-light);
}

.accordion-bordered .accordion-item {
  border: none;
  border-bottom: 1px solid var(--color-border-light);
}

/* Card Style Accordion */
.accordion-cards .accordion-item {
  background: var(--color-bg-elevated-2);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-lg);
  margin-bottom: var(--spacing-md);
  overflow: hidden;
}

.accordion-cards .accordion-item:last-child {
  margin-bottom: 0;
}

.accordion-cards .accordion-header {
  border-radius: var(--radius-lg);
}

/* Minimal Accordion */
.accordion-minimal .accordion-header {
  padding: var(--spacing-md) 0;
  background: transparent;
}

.accordion-minimal .accordion-header:hover {
  background: transparent;
}

.accordion-minimal .accordion-item.active .accordion-header {
  background: transparent;
  color: var(--color-primary);
}

.accordion-minimal .accordion-body {
  padding: var(--spacing-md) 0 var(--spacing-lg);
  background: transparent;
}

/* Dark Accordion */
.accordion-dark .accordion-item {
  border-bottom-color: var(--color-border-medium);
}

.accordion-dark .accordion-header {
  background: var(--color-bg-elevated);
  color: var(--color-text-light);
}

.accordion-dark .accordion-header:hover {
  background: var(--color-bg-elevated-2);
}

.accordion-dark .accordion-item.active .accordion-header {
  background: var(--color-primary);
}

.accordion-dark .accordion-body {
  background: var(--color-bg-elevated);
  color: var(--color-text-light);
}

/* ===== Package/Pricing Accordion ===== */

.package-accordion .accordion-header {
  padding: var(--spacing-lg);
  flex-wrap: wrap;
}

.package-accordion .accordion-title {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}

.package-name {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
}

.package-price {
  font-size: var(--font-size-lg);
  color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
}

.accordion-item.active .package-price {
  color: var(--color-text-light);
}

.package-ideal {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted-light);
  font-weight: var(--font-weight-normal);
  font-style: italic;
}

.accordion-item.active .package-ideal {
  color: rgba(255, 255, 255, 0.8);
}

/* Package Features List */
.package-features {
  list-style: none;
  padding: 0;
  margin: var(--spacing-md) 0;
  color: var(--color-text-light);
}

.package-features li {
  padding: var(--spacing-sm) 0;
  border-bottom: 1px solid var(--color-border-medium);
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  color: var(--color-text-light);
}

.package-features li:last-child {
  border-bottom: none;
}

.accordion-dark .package-features li {
  border-bottom-color: var(--color-border-medium);
}

/* ===== Smooth Expand/Collapse Animation ===== */

@media (prefers-reduced-motion: reduce) {
  .accordion-content {
    transition: none;
  }
}

/* ===== FAQ Accordion ===== */

.faq-accordion .accordion-header {
  font-size: var(--font-size-lg);
  padding: var(--spacing-md) var(--spacing-lg);
}

.faq-accordion .accordion-body {
  padding: var(--spacing-md) var(--spacing-lg) var(--spacing-xl);
}

.faq-question {
  font-weight: var(--font-weight-semibold);
}

.faq-answer {
  color: var(--color-text-muted-light);
  line-height: var(--line-height-relaxed);
}
