/**
 * Gutenberg Block Styles - Frontend
 * Matches the original SocaFights site styling
 */

/* ==========================================================================
   Page Header
   ========================================================================== */

/* Page header styles are in main style.css */

/* ==========================================================================
   Content Layout
   ========================================================================== */

.page-content,
.entry-content {
    max-width: 100%;
    margin: 0;
    text-align: left;
}

/* Wide and Full alignments */
.alignwide {
    max-width: var(--container-wide);
    margin-left: auto;
    margin-right: auto;
}

.alignfull {
    max-width: 100%;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.aligncenter {
    margin-left: auto;
    margin-right: auto;
}

.alignleft {
    float: left;
    margin-right: var(--spacing-xl);
    margin-bottom: var(--spacing-md);
}

.alignright {
    float: right;
    margin-left: var(--spacing-xl);
    margin-bottom: var(--spacing-md);
}

/* ==========================================================================
   Typography Blocks
   ========================================================================== */

/* Headings */
.wp-block-heading,
.page-content h1,
.page-content h2,
.page-content h3,
.page-content h4,
.page-content h5,
.page-content h6,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
    font-family: var(--font-heading);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    line-height: 1.2;
    color: var(--color-primary);
    margin-top: var(--spacing-2xl);
    margin-bottom: var(--spacing-lg);
}

.page-content h1:first-child,
.entry-content h1:first-child,
.page-content h2:first-child,
.entry-content h2:first-child {
    margin-top: 0;
}

/* Centered headings (common in original site) */
.has-text-align-center {
    text-align: center;
}

/* Paragraphs */
.wp-block-paragraph,
.page-content p,
.entry-content p {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    line-height: 1.8;
    color: var(--color-gray-dark);
    margin-bottom: var(--spacing-lg);
}

/* Large text style */
.has-large-font-size {
    font-size: var(--text-xl);
    line-height: 1.6;
}

.has-x-large-font-size {
    font-size: var(--text-2xl);
    line-height: 1.5;
}

/* Lists */
.wp-block-list,
.page-content ul,
.page-content ol,
.entry-content ul,
.entry-content ol {
    font-size: var(--text-lg);
    line-height: 1.8;
    margin-bottom: var(--spacing-lg);
    padding-left: var(--spacing-xl);
}

.wp-block-list li,
.page-content li,
.entry-content li {
    margin-bottom: var(--spacing-sm);
}

/* ==========================================================================
   Media Blocks
   ========================================================================== */

/* Images */
.wp-block-image {
    margin-bottom: var(--spacing-xl);
}

.wp-block-image img {
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
}

.wp-block-image.is-style-rounded img {
    border-radius: var(--radius-full);
}

.wp-block-image figcaption {
    font-size: var(--text-sm);
    color: var(--color-gray-light);
    text-align: center;
    margin-top: var(--spacing-sm);
}

/* Gallery */
.wp-block-gallery {
    margin-bottom: var(--spacing-xl);
}

.wp-block-gallery .wp-block-image img {
    border-radius: var(--radius-md);
}

/* Video */
.wp-block-video,
.wp-block-embed {
    margin-bottom: var(--spacing-xl);
}

.wp-block-video video {
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
}

/* ==========================================================================
   Layout Blocks
   ========================================================================== */

/* Columns */
.wp-block-columns {
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.wp-block-column {
    flex-basis: 0;
    flex-grow: 1;
}

/* 3-column team layout (like original site) */
.wp-block-columns.is-layout-flex {
    display: flex;
    flex-wrap: wrap;
}

@media (max-width: 768px) {
    .wp-block-columns {
        flex-direction: column;
    }

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

/* Group/Container */
.wp-block-group {
    margin-bottom: var(--spacing-xl);
}

.wp-block-group.has-background {
    padding: var(--spacing-xl);
    border-radius: var(--radius-md);
}

/* Cover Block */
.wp-block-cover {
    margin-bottom: var(--spacing-xl);
    border-radius: var(--radius-md);
    overflow: hidden;
    min-height: 400px;
}

.wp-block-cover .wp-block-cover__inner-container {
    max-width: var(--container-max);
    padding: var(--spacing-2xl);
}

.wp-block-cover h2,
.wp-block-cover h3 {
    color: var(--color-white);
}

/* ==========================================================================
   Component Blocks
   ========================================================================== */

/* Buttons */
.wp-block-button {
    margin-bottom: var(--spacing-md);
}

.wp-block-button__link {
    display: inline-block;
    padding: var(--spacing-md) var(--spacing-xl);
    font-family: var(--font-heading);
    font-size: var(--text-base);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    border-radius: var(--radius-sm);
    background-color: var(--color-primary);
    color: var(--color-white);
    transition: all var(--transition-base);
    border: 2px solid var(--color-primary);
}

.wp-block-button__link:hover {
    background-color: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: var(--color-white);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* Outline button style */
.is-style-outline .wp-block-button__link {
    background-color: transparent;
    color: var(--color-primary);
}

.is-style-outline .wp-block-button__link:hover {
    background-color: var(--color-primary);
    color: var(--color-white);
}

/* Quote Block */
.wp-block-quote {
    border-left: 4px solid var(--color-primary);
    padding: var(--spacing-lg) var(--spacing-xl);
    margin: var(--spacing-xl) 0;
    background-color: var(--color-light-gray);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
}

.wp-block-quote p {
    font-size: var(--text-xl);
    font-style: italic;
    margin-bottom: var(--spacing-sm);
}

.wp-block-quote cite {
    font-size: var(--text-base);
    color: var(--color-gray);
    font-style: normal;
    font-weight: 500;
}

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

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

.wp-block-pullquote p {
    font-size: var(--text-2xl);
    font-family: var(--font-heading);
    color: var(--color-primary);
}

/* Separator/Divider */
.wp-block-separator {
    border: none;
    height: 4px;
    background: linear-gradient(to right, transparent, var(--color-primary), transparent);
    margin: var(--spacing-2xl) auto;
    max-width: 200px;
}

.wp-block-separator.is-style-wide {
    max-width: 100%;
    background: var(--color-primary);
}

.wp-block-separator.is-style-dots {
    background: none;
    text-align: center;
    height: auto;
}

.wp-block-separator.is-style-dots::before {
    content: '• • •';
    color: var(--color-primary);
    font-size: var(--text-xl);
    letter-spacing: var(--spacing-md);
}

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

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

.wp-block-table th,
.wp-block-table td {
    padding: var(--spacing-md);
    border: 1px solid var(--color-light-gray);
    text-align: left;
}

.wp-block-table th {
    background-color: var(--color-dark);
    color: var(--color-white);
    font-family: var(--font-heading);
    text-transform: uppercase;
}

.wp-block-table tr:nth-child(even) {
    background-color: var(--color-light-gray);
}

/* ==========================================================================
   Custom Color Classes (matching original site)
   ========================================================================== */

.has-primary-color {
    color: var(--color-primary);
}

.has-primary-background-color {
    background-color: var(--color-primary);
}

.has-dark-color {
    color: var(--color-dark);
}

.has-dark-background-color {
    background-color: var(--color-dark);
}

.has-white-color {
    color: var(--color-white);
}

.has-white-background-color {
    background-color: var(--color-white);
}

.has-gray-color {
    color: var(--color-gray);
}

.has-light-gray-background-color {
    background-color: var(--color-light-gray);
}

/* ==========================================================================
   Team Member Card Style (common on About pages)
   ========================================================================== */

.team-member,
.wp-block-column.team-card {
    text-align: center;
}

.team-member img,
.wp-block-column.team-card img {
    margin: 0 auto var(--spacing-lg);
    max-width: 250px;
}

.team-member h3,
.wp-block-column.team-card h3 {
    color: var(--color-primary);
    margin-bottom: var(--spacing-xs);
}

.team-member .role,
.wp-block-column.team-card h4 {
    font-family: var(--font-heading);
    font-style: italic;
    color: var(--color-dark);
    text-transform: uppercase;
    font-size: var(--text-base);
    margin-bottom: var(--spacing-md);
}

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

@media (max-width: 768px) {
    .page-content h1,
    .entry-content h1 {
        font-size: var(--text-4xl);
    }

    .page-content h2,
    .entry-content h2 {
        font-size: var(--text-3xl);
    }

    .wp-block-paragraph,
    .page-content p,
    .entry-content p {
        font-size: var(--text-base);
    }

    .wp-block-columns {
        gap: var(--spacing-lg);
    }

    .alignleft,
    .alignright {
        float: none;
        margin-left: 0;
        margin-right: 0;
    }
}
