/**
 * Sierra at Tahoe - Details/Accordion Block Styling
 * Enhanced styling for core/details block based on Figma designs
 * Supports color variations and custom icons
 */

/* =============================================================================
   Base Details Block Styling
   ============================================================================= */

/* Base styling for all details elements - Closed state (Light) */
.wp-block-details,
details {
  border: none;
  border-radius: 40px;
  margin-bottom: var(--wp--preset--spacing--small);
  overflow: hidden;
  box-shadow: none;
  transition: all 0.3s ease;
  background-color: var(--wp--preset--color--module-background);
}

/* Summary (clickable header) styling - Closed state */
.wp-block-details summary,
details summary {
  padding: 0 0 0 16px;
  cursor: pointer;
  font-family: var(--wp--preset--font-family--gt-standard);
  font-size: 22px;
  line-height: 32px;
  position: relative;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  outline: none;
  user-select: none;
  list-style: none;
  background-color: transparent;
  color: var(--wp--preset--color--deep-alpine);
}
.wp-block-details summary strong,
details summary strong {
  font-weight: 600;
}

/* Open state - transitions to green with tighter border radius */
.wp-block-details[open],
details[open] {
  background-color: var(--wp--preset--color--sugar-pine-green);
  border-radius: 24px;
}

.wp-block-details[open] summary,
details[open] summary {
  background-color: transparent;
  color: var(--wp--preset--color--snowcap-sage);
  padding: 0 0 0 16px;
}

/* Remove default summary marker */
.wp-block-details summary::-webkit-details-marker,
details summary::-webkit-details-marker {
  display: none;
}

.wp-block-details summary::marker,
details summary::marker {
  display: none;
  content: '';
}

/* Content area styling - inherits green background when open */
.wp-block-details[open] summary ~ *,
details[open] summary ~ * {
  padding: 8px 96px 16px 24px;
  margin: 0;
  font-family: var(--wp--preset--font-family--gt-standard);
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
  color: var(--wp--preset--color--snowcap-sage);
  background-color: transparent;
  animation: slideDown 0.3s ease-out;
}

/* Content area container */
.wp-block-details .wp-block-details__content,
details .details-content {
  overflow: hidden;
  background-color: transparent;
}

/* =============================================================================
   Custom Caret Icon (Circular Button)
   ============================================================================= */

/* Custom icon container - Closed state: purple circle with light arrow */
.wp-block-details summary::after,
details summary::after {
  content: '';
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  border-radius: 40px;
  background-color: var(--wp--preset--color--last-light);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M7 10l5 5 5-5' stroke='%23F5FFF0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: 24px 24px;
  background-repeat: no-repeat;
  background-position: center;
  transition: all 0.3s ease;
  flex-shrink: 0;
  transform: rotate(0deg);
}

/* Open state: light circle with purple arrow, rotated */
.wp-block-details[open] summary::after,
details[open] summary::after {
  transform: rotate(180deg);
  background-color: var(--wp--preset--color--snowcap-sage);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M7 10l5 5 5-5' stroke='%23868EE2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* Icon hover state */
.wp-block-details summary:hover::after,
details summary:hover::after {
  transform: scale(1.05);
}

.wp-block-details[open] summary:hover::after,
details[open] summary:hover::after {
  transform: rotate(180deg) scale(1.05);
}

/* =============================================================================
   Color Variations
   ============================================================================= */

/* Green Accordion */
.wp-block-details.is-style-sierra-accordion-green,
.sierra-accordion-green {
  background-color: var(--wp--preset--color--sugar-pine-green);
  color: var(--wp--preset--color--snowcap-sage);
}

.wp-block-details.is-style-sierra-accordion-green summary,
.sierra-accordion-green summary {
  background-color: var(--wp--preset--color--sugar-pine-green);
  color: var(--wp--preset--color--snowcap-sage);
}

.wp-block-details.is-style-sierra-accordion-green summary:hover,
.sierra-accordion-green summary:hover {
  background-color: rgba(10, 106, 88, 0.9);
  transform: translateY(-1px);
}

.wp-block-details.is-style-sierra-accordion-green[open] summary ~ *,
.sierra-accordion-green[open] summary ~ * {
  background-color: var(--wp--preset--color--sugar-pine-green);
  color: var(--wp--preset--color--snowcap-sage);
}

/* Purple Accordion */
.wp-block-details.is-style-sierra-accordion-purple,
.sierra-accordion-purple {
  background-color: var(--wp--preset--color--last-light);
  color: var(--wp--preset--color--snowcap-sage);
}

.wp-block-details.is-style-sierra-accordion-purple summary,
.sierra-accordion-purple summary {
  background-color: var(--wp--preset--color--last-light);
  color: var(--wp--preset--color--snowcap-sage);
}

.wp-block-details.is-style-sierra-accordion-purple summary:hover,
.sierra-accordion-purple summary:hover {
  background-color: rgba(134, 142, 236, 0.9);
  transform: translateY(-1px);
}

.wp-block-details.is-style-sierra-accordion-purple[open] summary ~ *,
.sierra-accordion-purple[open] summary ~ * {
  background-color: var(--wp--preset--color--last-light);
  color: var(--wp--preset--color--snowcap-sage);
}

/* Orange Accordion */
.wp-block-details.is-style-sierra-accordion-orange,
.sierra-accordion-orange {
  background-color: var(--wp--preset--color--sierra-gold);
  color: var(--wp--preset--color--deep-alpine);
}

.wp-block-details.is-style-sierra-accordion-orange summary,
.sierra-accordion-orange summary {
  background-color: var(--wp--preset--color--sierra-gold);
  color: var(--wp--preset--color--deep-alpine);
}

.wp-block-details.is-style-sierra-accordion-orange summary:hover,
.sierra-accordion-orange summary:hover {
  background-color: rgba(249, 183, 80, 0.9);
  transform: translateY(-1px);
}

.wp-block-details.is-style-sierra-accordion-orange[open] summary ~ *,
.sierra-accordion-orange[open] summary ~ * {
  background-color: var(--wp--preset--color--sierra-gold);
  color: var(--wp--preset--color--deep-alpine);
}

/* Orange accordion needs different icon color */
.wp-block-details.is-style-sierra-accordion-orange summary::after,
.sierra-accordion-orange summary::after {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23142C2D' stroke-width='2' stroke-linecap='round' d='M12 8v8M8 12h8'/%3E%3C/svg%3E");
}

.wp-block-details.is-style-sierra-accordion-orange[open] summary::after,
.sierra-accordion-orange[open] summary::after {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23142C2D' stroke-width='2' stroke-linecap='round' d='M8 12h8'/%3E%3C/svg%3E");
}

/* Light Accordion */
.wp-block-details.is-style-sierra-accordion-light,
.sierra-accordion-light {
  background-color: var(--wp--preset--color--snowcap-sage);
  color: var(--wp--preset--color--deep-alpine);
  border: 1px solid var(--wp--preset--color--sugar-pine-green-20);
}

.wp-block-details.is-style-sierra-accordion-light summary,
.sierra-accordion-light summary {
  background-color: var(--wp--preset--color--snowcap-sage);
  color: var(--wp--preset--color--deep-alpine);
}

.wp-block-details.is-style-sierra-accordion-light summary:hover,
.sierra-accordion-light summary:hover {
  background-color: rgba(245, 255, 240, 0.8);
  border-color: var(--wp--preset--color--sugar-pine-green);
  transform: translateY(-1px);
}

.wp-block-details.is-style-sierra-accordion-light[open] summary ~ *,
.sierra-accordion-light[open] summary ~ * {
  background-color: var(--wp--preset--color--snowcap-sage);
  color: var(--wp--preset--color--deep-alpine);
}

/* Light accordion needs different icon color */
.wp-block-details.is-style-sierra-accordion-light summary::after,
.sierra-accordion-light summary::after {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23142C2D' stroke-width='2' stroke-linecap='round' d='M12 8v8M8 12h8'/%3E%3C/svg%3E");
}

.wp-block-details.is-style-sierra-accordion-light[open] summary::after,
.sierra-accordion-light[open] summary::after {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none'%3E%3Cpath stroke='%23142C2D' stroke-width='2' stroke-linecap='round' d='M8 12h8'/%3E%3C/svg%3E");
}

/* =============================================================================
   Animation Effects
   ============================================================================= */

/* Slide down animation for content */
@keyframes slideDown {
  from {
    opacity: 0;
    max-height: 0;
  }
  to {
    opacity: 1;
    max-height: 500px;
  }
}

/* Icon rotation animation */
.wp-block-details summary::after,
details summary::after {
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* =============================================================================
   Focus States & Accessibility
   ============================================================================= */

/* Focus styling for keyboard navigation */
.wp-block-details:focus-within {
  outline: 2px solid var(--wp--preset--color--sugar-pine-green);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(10, 106, 88, 0.1);
}

.wp-block-details summary:focus {
  outline: none;
}

.wp-block-details summary:focus-visible {
  outline: none;
}

/* Focus for different color variants */
.wp-block-details.is-style-sierra-accordion-purple:focus-within {
  outline-color: var(--wp--preset--color--last-light);
  box-shadow: 0 0 0 4px rgba(134, 142, 236, 0.1);
}

.wp-block-details.is-style-sierra-accordion-orange:focus-within {
  outline-color: var(--wp--preset--color--sierra-gold);
  box-shadow: 0 0 0 4px rgba(249, 183, 80, 0.1);
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  .wp-block-details,
  details {
    border: 2px solid currentColor;
  }

  .wp-block-details summary::after,
  details summary::after {
    opacity: 1;
    border: 1px solid currentColor;
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
  .wp-block-details,
  details,
  .wp-block-details summary,
  details summary,
  .wp-block-details summary::after,
  details summary::after {
    transition: none;
    animation: none;
  }

  .wp-block-details[open] summary ~ *,
  details[open] summary ~ * {
    animation: none;
  }
}

/* =============================================================================
   Group/Stack Styling
   ============================================================================= */

/* Accordion group container */
.wp-block-group.accordion-group,
.accordion-stack {
  gap: var(--wp--preset--spacing--small);
}

.wp-block-group.accordion-group .wp-block-details,
.accordion-stack .wp-block-details,
.accordion-stack details {
  margin-bottom: 0;
}

/* First and last accordion in group */
.wp-block-group.accordion-group .wp-block-details:first-child,
.accordion-stack .wp-block-details:first-child,
.accordion-stack details:first-child {
  margin-top: 0;
}

.wp-block-group.accordion-group .wp-block-details:last-child,
.accordion-stack .wp-block-details:last-child,
.accordion-stack details:last-child {
  margin-bottom: 0;
}

/* =============================================================================
   Responsive Design
   ============================================================================= */

/* Tablet adjustments */
@media (max-width: 768px) {
  .wp-block-details,
  details {
    border-radius: 32px;
  }

  .wp-block-details[open],
  details[open] {
    border-radius: 20px;
  }

  .wp-block-details summary,
  details summary {
    padding: 0 0 0 12px;
    font-size: 20px;
    line-height: 28px;
    gap: 16px;
  }

  .wp-block-details[open] summary ~ *,
  details[open] summary ~ * {
    padding: 8px 76px 12px 20px;
    margin: 0;
    font-size: 16px;
    line-height: 22px;
  }

  .wp-block-details summary::after,
  details summary::after {
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
    background-size: 20px 20px;
  }
}

/* Mobile adjustments */
@media (max-width: 480px) {
  .wp-block-details,
  details {
    border-radius: 28px;
  }

  .wp-block-details[open],
  details[open] {
    border-radius: 18px;
  }

  .wp-block-details summary,
  details summary {
    padding: 0 0 0 12px;
    font-size: 18px;
    line-height: 26px;
    gap: 12px;
  }

  .wp-block-details summary::after,
  details summary::after {
    width: 32px;
    height: 32px;
    min-width: 32px;
    min-height: 32px;
    background-size: 18px 18px;
  }

  .wp-block-details[open] summary ~ *,
  details[open] summary ~ * {
    padding: 8px 56px 12px 16px;
    margin: 0;
    font-size: 16px;
    line-height: 22px;
  }
}

/* =============================================================================
   Print Styles
   ============================================================================= */

@media print {
  .wp-block-details,
  details {
    break-inside: avoid;
    page-break-inside: avoid;
  }

  .wp-block-details summary::after,
  details summary::after {
    display: none;
  }

  .wp-block-details[open] summary ~ *,
  details[open] summary ~ * {
    display: block !important;
    animation: none;
  }
}