/**
 * Block Editor Styles
 *
 * Additional styles for WordPress blocks on the frontend
 *
 * @package FFOA_Custom
 * @since 1.0.0
 */

/* ==========================================================================
   Block-specific styles
   ========================================================================== */

/* Buttons */
.wp-block-button__link {
    text-decoration: none;
    cursor: pointer;
}

.wp-block-button.is-style-outline .wp-block-button__link {
    background-color: transparent;
}

/* Columns */
.wp-block-columns {
    margin-bottom: var(--space-xl, 2rem);
}

.wp-block-column {
    margin-bottom: var(--space-lg, 1.5rem);
}

@media (min-width: 782px) {
    .wp-block-column {
        margin-bottom: 0;
    }
}

/* Group */
.wp-block-group {
    margin-bottom: var(--space-xl, 2rem);
}

.wp-block-group.has-background {
    padding: var(--space-xl, 2rem);
}

/* Cover */
.wp-block-cover {
    margin-bottom: var(--space-xl, 2rem);
    min-height: 400px;
}

.wp-block-cover h1,
.wp-block-cover h2,
.wp-block-cover h3,
.wp-block-cover h4,
.wp-block-cover h5,
.wp-block-cover h6 {
    color: inherit;
}

/* Image */
.wp-block-image {
    margin-bottom: var(--space-lg, 1.5rem);
}

.wp-block-image figcaption {
    margin-top: var(--space-sm, 0.5rem);
    font-size: var(--font-size-sm, 0.875rem);
    color: var(--color-text-secondary, #666);
    text-align: center;
}

/* Gallery */
.wp-block-gallery {
    margin-bottom: var(--space-xl, 2rem);
}

/* Quote */
.wp-block-quote {
    margin: var(--space-xl, 2rem) 0;
    padding-left: var(--space-lg, 1.5rem);
    border-left: 4px solid var(--color-primary, #333);
}

.wp-block-quote cite {
    display: block;
    margin-top: var(--space-sm, 0.5rem);
    font-size: var(--font-size-sm, 0.875rem);
    font-style: normal;
    color: var(--color-text-secondary, #666);
}

.wp-block-quote.is-large,
.wp-block-quote.is-style-large {
    padding-left: 0;
    border-left: none;
}

.wp-block-quote.is-large p,
.wp-block-quote.is-style-large p {
    font-size: var(--font-size-xl, 1.25rem);
}

/* Pullquote */
.wp-block-pullquote {
    margin: var(--space-2xl, 3rem) 0;
    padding: var(--space-xl, 2rem);
    text-align: center;
    border-top: 4px solid var(--color-primary, #333);
    border-bottom: 4px solid var(--color-primary, #333);
}

.wp-block-pullquote blockquote {
    margin: 0;
    padding: 0;
    border: none;
}

/* Separator */
.wp-block-separator {
    margin: var(--space-xl, 2rem) auto;
    border: none;
    border-top: 2px solid var(--color-primary, #333);
}

.wp-block-separator.is-style-wide {
    max-width: 100%;
}

.wp-block-separator.is-style-dots::before {
    content: '···';
    font-size: var(--font-size-2xl, 1.5rem);
    letter-spacing: var(--letter-spacing-wider, 0.05em);
}

/* Table */
.wp-block-table {
    margin-bottom: var(--space-xl, 2rem);
    overflow-x: auto;
}

.wp-block-table table {
    width: 100%;
    border-collapse: collapse;
}

.wp-block-table th,
.wp-block-table td {
    padding: var(--space-sm, 0.5rem) var(--space-md, 1rem);
    border: 1px solid var(--color-light, #e0e0e0);
}

.wp-block-table th {
    font-weight: var(--font-weight-bold, 700);
    text-align: left;
    background-color: var(--color-light, #f5f5f5);
}

.wp-block-table.is-style-stripes tbody tr:nth-child(odd) {
    background-color: var(--color-light, #f5f5f5);
}

/* Code */
.wp-block-code {
    margin-bottom: var(--space-lg, 1.5rem);
    padding: var(--space-md, 1rem);
    background-color: var(--color-light, #f5f5f5);
    border-radius: var(--radius-sm, 4px);
    overflow-x: auto;
}

.wp-block-code code {
    font-family: var(--font-family-mono, monospace);
    font-size: var(--font-size-sm, 0.875rem);
    background: transparent;
}

/* Preformatted */
.wp-block-preformatted {
    margin-bottom: var(--space-lg, 1.5rem);
    padding: var(--space-md, 1rem);
    background-color: var(--color-light, #f5f5f5);
    border-radius: var(--radius-sm, 4px);
    overflow-x: auto;
    font-family: var(--font-family-mono, monospace);
    font-size: var(--font-size-sm, 0.875rem);
}

/* Media & Text */
.wp-block-media-text {
    margin-bottom: var(--space-xl, 2rem);
}

.wp-block-media-text .wp-block-media-text__content {
    padding: var(--space-lg, 1.5rem);
}

/* Embed */
.wp-block-embed {
    margin-bottom: var(--space-xl, 2rem);
}

.wp-block-embed figcaption {
    margin-top: var(--space-sm, 0.5rem);
    font-size: var(--font-size-sm, 0.875rem);
    color: var(--color-text-secondary, #666);
    text-align: center;
}

/* ==========================================================================
   Responsive adjustments
   ========================================================================== */

@media (max-width: 768px) {
    .wp-block-cover {
        min-height: 300px;
    }

    .wp-block-columns {
        display: block;
    }

    .wp-block-column {
        flex-basis: 100% !important;
    }

    .wp-block-media-text.is-stacked-on-mobile {
        display: block;
    }

    .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media {
        margin-bottom: var(--space-md, 1rem);
    }
}
