/*
 * Callout Component
 * Alert-style callouts with icons, titles, and content
 */

/* Callout Base */
.callout {
    display: flex;
    gap: 1rem;
    padding: 1rem 1rem 1rem 1.5rem;
    border-radius: 0;
    border: none;
    border-left: 2px solid var(--theme-border);
    background: transparent;
    position: relative;
}

.callout > * {
    position: relative;
    z-index: 1;
}

/* Callout Icon */
.callout-icon {
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.125rem;
}

.callout-icon svg,
.callout-icon img {
    width: 100%;
    height: 100%;
}

/* Callout Content */
.callout-content {
    flex: 1;
    font-size: var(--font-size-body);
}

.callout-title {
    font-weight: 500;
    font-size: var(--font-size-body);
    color: inherit;
    margin-bottom: 0.5rem;
    letter-spacing: -0.01em;
}

.callout-content p {
    font-size: var(--font-size-body);
    line-height: 1.6;
    margin: 0;
    color: var(--theme-text-secondary);
}

/* Callout Variants */

/* Info Callout */
.callout-info {
    border-left-color: var(--color-info);
}

.callout-info .callout-icon {
    color: var(--color-info);
}

.callout-info .callout-title {
    color: var(--theme-text-primary);
}

/* Success Callout */
.callout-success {
    border-left-color: var(--color-success);
}

.callout-success .callout-icon {
    color: var(--color-success);
}

.callout-success .callout-title {
    color: var(--theme-text-primary);
}

/* Warning Callout */
.callout-warning {
    border-left-color: var(--color-warning);
}

.callout-warning .callout-icon {
    color: var(--color-warning);
}

.callout-warning .callout-title {
    color: var(--theme-text-primary);
}

/* Error Callout */
.callout-error {
    border-left-color: var(--color-error);
}

.callout-error .callout-icon {
    color: var(--color-error);
}

.callout-error .callout-title {
    color: var(--theme-text-primary);
}

/* Sizes */

/* Small Callout */
.callout-sm {
    padding: 0.75rem;
    gap: 0.75rem;
}

.callout-sm .callout-icon {
    width: 16px;
    height: 16px;
}

.callout-sm .callout-icon svg,
.callout-sm .callout-icon img {
    width: 14px;
    height: 14px;
}

.callout-sm .callout-title {
    font-size: 0.8125rem;
}

.callout-sm .callout-content p {
    font-size: 0.8125rem;
}

/* Large Callout */
.callout-lg {
    padding: 1.25rem;
    gap: 1.25rem;
}

.callout-lg .callout-icon {
    width: 24px;
    height: 24px;
}

.callout-lg .callout-icon svg,
.callout-lg .callout-icon img {
    width: 20px;
    height: 20px;
}

.callout-lg .callout-title {
    font-size: 1rem;
}

.callout-lg .callout-content p {
    font-size: 1rem;
}

/* Dismissible Callout */
.callout-dismissible {
    padding-right: 2.5rem;
}

.callout-close {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    background: none;
    border: none;
    color: var(--theme-text-tertiary);
    cursor: pointer;
    padding: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--border-radius-sm);
    transition: all 0.2s;
    z-index: 2;
}

.callout-close:hover {
    background: rgba(0, 0, 0, 0.1);
    color: var(--theme-text-primary);
}

.callout-close svg {
    width: 14px;
    height: 14px;
}

/* Solid Variant */
.callout-solid.callout-info {
    background: var(--color-info);
    border-left-color: var(--color-info);
}

.callout-solid.callout-info .callout-title,
.callout-solid.callout-info .callout-content p {
    color: white;
}

.callout-solid.callout-info .callout-icon {
    color: white;
}

.callout-solid.callout-success {
    background: var(--color-success);
    border-left-color: var(--color-success);
}

.callout-solid.callout-success .callout-title,
.callout-solid.callout-success .callout-content p {
    color: white;
}

.callout-solid.callout-success .callout-icon {
    color: white;
}

.callout-solid.callout-warning {
    background: var(--color-warning);
    border-left-color: var(--color-warning);
}

.callout-solid.callout-warning .callout-title,
.callout-solid.callout-warning .callout-content p {
    color: white;
}

.callout-solid.callout-warning .callout-icon {
    color: white;
}

.callout-solid.callout-error {
    background: var(--color-error);
    border-left-color: var(--color-error);
}

.callout-solid.callout-error .callout-title,
.callout-solid.callout-error .callout-content p {
    color: white;
}

.callout-solid.callout-error .callout-icon {
    color: white;
}

/* Responsive */
@media (max-width: 640px) {
    .callout {
        padding: 0.875rem;
        gap: 0.875rem;
    }

    .callout-lg {
        padding: 1rem;
    }
}
