/* Global Accordion Styles - Bit Card Panel Matching */

/* ===========================================
   Default Accordion Styling (matches bit-card panels)
   =========================================== */

/* Base accordion button - matches bit-card header sizing */
.accordion-button {
    padding: 0.25rem 1rem !important;
    min-height: 45px !important;
    font-size: .925rem !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    color: #1a202c !important;
    display: flex;
    align-items: center;
    gap: 12px;
}

/* Auto-style icons in accordion buttons to match bit-card icon boxes */
.accordion-button > i,
.accordion-button > .bi,
.accordion-button > [class^="bi-"],
.accordion-button > [class*=" bi-"] {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem !important;
    flex-shrink: 0;
    box-shadow: 0 2px 4px -1px rgba(0, 0, 0, 0.1);
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-primary) 20%, white) 0%,
        color-mix(in srgb, var(--bs-primary) 35%, white) 100%);
    color: var(--bs-primary);
    margin-right: 0 !important; /* Remove me-2 margin since we use gap */
}

/* Manual accordion-icon class for explicit icon boxes */
.accordion-button .accordion-icon {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
    box-shadow: 0 2px 4px -1px rgba(0, 0, 0, 0.1);
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-primary) 20%, white) 0%,
        color-mix(in srgb, var(--bs-primary) 35%, white) 100%);
    color: var(--bs-primary);
}

/* Icons inside accordion-icon wrapper should not have box styling */
.accordion-button .accordion-icon i,
.accordion-button .accordion-icon .bi {
    width: auto;
    height: auto;
    min-width: auto;
    border-radius: 0;
    box-shadow: none;
    background: none !important;
    color: inherit;
    margin-right: 0 !important;
}

/* Variant icon colors */
.accordion-button .accordion-icon.icon-primary,
.accordion-button > i.icon-primary {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-primary) 20%, white) 0%,
        color-mix(in srgb, var(--bs-primary) 35%, white) 100%);
    color: var(--bs-primary);
}

.accordion-button .accordion-icon.icon-secondary,
.accordion-button > i.icon-secondary {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-secondary) 20%, white) 0%,
        color-mix(in srgb, var(--bs-secondary) 35%, white) 100%);
    color: var(--bs-secondary);
}

.accordion-button .accordion-icon.icon-success,
.accordion-button > i.icon-success {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-success) 20%, white) 0%,
        color-mix(in srgb, var(--bs-success) 35%, white) 100%);
    color: var(--bs-success);
}

.accordion-button .accordion-icon.icon-danger,
.accordion-button > i.icon-danger {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-danger) 20%, white) 0%,
        color-mix(in srgb, var(--bs-danger) 35%, white) 100%);
    color: var(--bs-danger);
}

.accordion-button .accordion-icon.icon-warning,
.accordion-button > i.icon-warning {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-warning) 25%, white) 0%,
        color-mix(in srgb, var(--bs-warning) 40%, white) 100%);
    color: color-mix(in srgb, var(--bs-warning) 90%, black);
}

.accordion-button .accordion-icon.icon-info,
.accordion-button > i.icon-info {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-info) 20%, white) 0%,
        color-mix(in srgb, var(--bs-info) 35%, white) 100%);
    color: color-mix(in srgb, var(--bs-info) 80%, black);
}

/* Accordion item border styling to match bit-card */
.accordion-item {
    border: 1px solid #e2e8f0 !important;
    border-radius: 12px !important;
    overflow: hidden;
    margin-bottom: 0.5rem;
}

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

/* Highlight active accordion panels */
.accordion-button:not(.collapsed) {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-primary) 8%, white) 0%,
        color-mix(in srgb, var(--bs-primary) 3%, white) 100%) !important;
    color: #1a202c !important;
}

/* Slightly reduce accordion body padding for consistency */
.accordion-body {
    padding: 1rem !important;
    font-size: 14px !important;
    font-weight: 400 !important;
}

/* Reduce focus shadow size */
.accordion-button:focus {
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-primary-rgb), 0.25) !important;
}

/* Smoother transitions */
.accordion-collapse {
    transition: all 0.3s ease !important;
}

/* Hover effect for better interactivity */
.accordion-button:hover {
    background-color: rgba(var(--bs-gray-500), 0.05) !important;
}

.accordion-button:not(.collapsed):hover {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-primary) 10%, white) 0%,
        color-mix(in srgb, var(--bs-primary) 5%, white) 100%) !important;
}

/* ===========================================
   Color Variant Accordions (like bit-card variants)
   =========================================== */

/* Success Variant */
.accordion-success .accordion-button > i,
.accordion-success .accordion-button > .bi,
.accordion-success .accordion-button .accordion-icon {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-success) 20%, white) 0%,
        color-mix(in srgb, var(--bs-success) 35%, white) 100%) !important;
    color: var(--bs-success) !important;
}

/* Base success accordion button - override Bootstrap's background-color */
.accordion.accordion-success .accordion-item .accordion-button,
.accordion-success .accordion-button {
    background-color: transparent !important;
}

/* Closed accordion - lighter green background */
.accordion.accordion-success .accordion-item .accordion-button.collapsed,
.accordion-success .accordion-button.collapsed {
    background: color-mix(in srgb, var(--bs-success) 10%, white) !important;
    background-color: color-mix(in srgb, var(--bs-success) 10%, white) !important;
}

/* Closed accordion hover - slightly darker */
.accordion.accordion-success .accordion-item .accordion-button.collapsed:hover,
.accordion-success .accordion-button.collapsed:hover {
    background: color-mix(in srgb, var(--bs-success) 15%, white) !important;
    background-color: color-mix(in srgb, var(--bs-success) 15%, white) !important;
}

/* Open accordion - darker green background */
.accordion.accordion-success .accordion-item .accordion-button:not(.collapsed),
.accordion-success .accordion-button:not(.collapsed) {
    background: color-mix(in srgb, var(--bs-success) 22%, white) !important;
    background-color: color-mix(in srgb, var(--bs-success) 22%, white) !important;
}

/* Open accordion hover - even darker */
.accordion.accordion-success .accordion-item .accordion-button:not(.collapsed):hover,
.accordion-success .accordion-button:not(.collapsed):hover {
    background: color-mix(in srgb, var(--bs-success) 28%, white) !important;
    background-color: color-mix(in srgb, var(--bs-success) 28%, white) !important;
}

.accordion-success .accordion-button:focus {
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-success-rgb), 0.25) !important;
}

/* Success accordion item border */
.accordion-success.accordion-item,
.accordion-success .accordion-item {
    border-color: color-mix(in srgb, var(--bs-success) 30%, white) !important;
}

/* Primary Variant */
.accordion-primary .accordion-button > i,
.accordion-primary .accordion-button > .bi,
.accordion-primary .accordion-button .accordion-icon {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-primary) 20%, white) 0%,
        color-mix(in srgb, var(--bs-primary) 35%, white) 100%);
    color: var(--bs-primary);
}

.accordion-primary .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-primary) 8%, white) 0%,
        color-mix(in srgb, var(--bs-primary) 3%, white) 100%) !important;
}

.accordion-primary .accordion-button:not(.collapsed):hover {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-primary) 10%, white) 0%,
        color-mix(in srgb, var(--bs-primary) 5%, white) 100%) !important;
}

.accordion-primary .accordion-button:focus {
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-primary-rgb), 0.25) !important;
}

/* Danger Variant */
.accordion-danger .accordion-button > i,
.accordion-danger .accordion-button > .bi,
.accordion-danger .accordion-button .accordion-icon {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-danger) 20%, white) 0%,
        color-mix(in srgb, var(--bs-danger) 35%, white) 100%);
    color: var(--bs-danger);
}

.accordion-danger .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-danger) 8%, white) 0%,
        color-mix(in srgb, var(--bs-danger) 3%, white) 100%) !important;
}

.accordion-danger .accordion-button:not(.collapsed):hover {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-danger) 10%, white) 0%,
        color-mix(in srgb, var(--bs-danger) 5%, white) 100%) !important;
}

.accordion-danger .accordion-button:focus {
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-danger-rgb), 0.25) !important;
}

/* Warning Variant */
.accordion-warning .accordion-button > i,
.accordion-warning .accordion-button > .bi,
.accordion-warning .accordion-button .accordion-icon {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-warning) 25%, white) 0%,
        color-mix(in srgb, var(--bs-warning) 40%, white) 100%);
    color: color-mix(in srgb, var(--bs-warning) 90%, black);
}

.accordion-warning .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-warning) 10%, white) 0%,
        color-mix(in srgb, var(--bs-warning) 5%, white) 100%) !important;
}

.accordion-warning .accordion-button:not(.collapsed):hover {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-warning) 12%, white) 0%,
        color-mix(in srgb, var(--bs-warning) 7%, white) 100%) !important;
}

.accordion-warning .accordion-button:focus {
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-warning-rgb), 0.25) !important;
}

/* Info Variant */
.accordion-info .accordion-button > i,
.accordion-info .accordion-button > .bi,
.accordion-info .accordion-button .accordion-icon {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-info) 20%, white) 0%,
        color-mix(in srgb, var(--bs-info) 35%, white) 100%);
    color: color-mix(in srgb, var(--bs-info) 80%, black);
}

.accordion-info .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-info) 8%, white) 0%,
        color-mix(in srgb, var(--bs-info) 3%, white) 100%) !important;
}

.accordion-info .accordion-button:not(.collapsed):hover {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-info) 10%, white) 0%,
        color-mix(in srgb, var(--bs-info) 5%, white) 100%) !important;
}

.accordion-info .accordion-button:focus {
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-info-rgb), 0.25) !important;
}

/* Secondary Variant */
.accordion-secondary .accordion-button > i,
.accordion-secondary .accordion-button > .bi,
.accordion-secondary .accordion-button .accordion-icon {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-secondary) 20%, white) 0%,
        color-mix(in srgb, var(--bs-secondary) 35%, white) 100%);
    color: var(--bs-secondary);
}

.accordion-secondary .accordion-button:not(.collapsed) {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-secondary) 8%, white) 0%,
        color-mix(in srgb, var(--bs-secondary) 3%, white) 100%) !important;
}

.accordion-secondary .accordion-button:not(.collapsed):hover {
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--bs-secondary) 10%, white) 0%,
        color-mix(in srgb, var(--bs-secondary) 5%, white) 100%) !important;
}

.accordion-secondary .accordion-button:focus {
    box-shadow: 0 0 0 0.15rem rgba(var(--bs-secondary-rgb), 0.25) !important;
}

/* ===========================================
   Compact Accordion Variant
   =========================================== */

.accordion-compact .accordion-button {
    padding: 0.2rem 0.75rem !important;
    font-size: .85rem !important;
    gap: 10px;
}

.accordion-compact .accordion-button > i,
.accordion-compact .accordion-button > .bi,
.accordion-compact .accordion-button .accordion-icon {
    width: 30px;
    height: 30px;
    min-width: 30px;
    font-size: 0.875rem !important;
}

.accordion-compact .accordion-body {
    padding: 0.75rem !important;
}

.accordion-compact .accordion-item {
    border-radius: 8px !important;
    margin-bottom: 0.375rem;
}

/* ===========================================
   Flush Accordion Variant
   =========================================== */

.accordion-flush .accordion-button {
    padding: 0.5rem 0 !important;
}

.accordion-flush .accordion-item {
    border-radius: 0 !important;
    border-left: none !important;
    border-right: none !important;
}

/* ===========================================
   Responsive Adjustments
   =========================================== */

@media (max-width: 768px) {
    .accordion-button {
        padding: 0.2rem 0.75rem !important;
        font-size: .85rem !important;
        gap: 10px;
    }

    .accordion-button > i,
    .accordion-button > .bi,
    .accordion-button .accordion-icon {
        width: 30px;
        height: 30px;
        min-width: 30px;
        font-size: 0.875rem !important;
    }

    .accordion-body {
        padding: 0.75rem !important;
    }
}
