/* Drop Cap Support */
.has-drop-cap:not(:focus)::first-letter {
    float: left;
    font-size: 3.6em;
    line-height: 0.68;
    margin: 0.05em 0.1em 0 0;
    text-transform: uppercase;
    font-style: normal;
    font-family: var(--serif-font);
}

@media screen and (max-width: 600px) {
    .has-drop-cap:not(:focus)::first-letter {
        font-size: 2.8em;
        margin: 0.05em 0.1em 0 0;
    }
}

/* Align Wide Support */
.alignwide {
    margin-left: -80px;
    margin-right: -80px;
    max-width: calc(100% + 160px);
}

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

/* Progressive reduction of alignwide margins */
@media only screen and (max-width: 1024px) {
    .alignwide {
        margin-left: -60px;
        margin-right: -60px;
        max-width: calc(100% + 120px);
    }
}

@media only screen and (max-width: 896px) {
    .alignwide {
        margin-left: -40px;
        margin-right: -40px;
        max-width: calc(100% + 80px);
    }
}

@media only screen and (max-width: 600px) {
    .alignwide {
        margin-left: -20px;
        margin-right: -20px;
        max-width: calc(100% + 40px);
    }

    .alignfull {
        width: 100%;
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
    }
}

/* Blockquote Styles */
.wp-block-quote {
    background-color: #f8f8f8;
    padding: .5rem 3rem;
    border-left: .3rem solid var(--accent-hover);
}

.wp-block-quote cite {
    display: block;
    font-size: 0.875em;
    font-style: italic;
    margin-top: 0.5em;
    color: #555;
}

@media screen and (max-width: 600px) {
    .wp-block-quote {
        margin: 1em 0;
        padding-left: 0.8em;
    }

    .wp-block-quote cite {
        font-size: 0.8em;
    }
}


/* Pull Quote Styles */
.wp-block-pullquote {
    text-align: center;
    font-family: var(--serif-font);

    border: 0 none;
    padding: 0;
}

.wp-block-pullquote::before,
.wp-block-pullquote::after {
    content: "";
    display: block;
    width: 10rem;
    height: 1px;
    background: black;
    margin: 2rem auto;
}

.wp-block-pullquote.alignleft {
    text-align: left;
}

.wp-block-pullquote.alignright {
    text-align: right;
}

@media (min-width: 768px) {
    .wp-block-pullquote.alignleft {
        float: left;
        width: 50%;
        margin-left: -10rem;
    }

    .wp-block-pullquote.alignright {
        float: right;
        width: 50%;
        margin-right: -10rem;
    }
}


.wp-block-pullquote blockquote {
    margin: 0;
    padding: 0;
    border: none;
    font-size: 1.7rem;
    background-color: transparent;
}

.wp-block-pullquote cite {
    display: block;
    font-size: 0.875em;
    font-style: italic;
    margin-top: 1em;
    color: #555;
}

@media screen and (max-width: 600px) {
    .wp-block-pullquote {
        margin: 1.5em 0;
        padding: 1.5em 0;
    }

    .wp-block-pullquote blockquote {
        font-size: 0.9em;
    }

    .wp-block-pullquote cite {
        font-size: 0.8em;
        margin-top: 0.8em;
    }
}

/* Separator Styles */
.wp-block-separator {
    border: none;
    border-bottom: 2px solid #ccc;
    margin: 2em auto;
    max-width: 100px;
}

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

.wp-block-separator.is-style-dots {
    border: none;
    text-align: center;
    max-width: none;
}

.wp-block-separator.is-style-dots::before {
    content: "\00b7 \00b7 \00b7";
    color: #666;
    font-size: 24px;
    letter-spacing: 1em;
    padding-left: 1em;
}

@media screen and (max-width: 600px) {
    .wp-block-separator {
        margin: 1.5em auto;
    }

    .wp-block-separator.is-style-dots::before {
        font-size: 20px;
        letter-spacing: 0.8em;
        padding-left: 0.8em;
    }
}

/* Base container responsiveness */
.wp-block-quote,
.wp-block-pullquote,
.alignwide,
.alignfull {
    word-break: break-word;
    overflow-wrap: break-word;
}

/* Previous styles remain the same */

/* Column Styles */
.wp-block-columns {
    display: flex;
    margin-bottom: 1.75em;
    box-sizing: border-box;
    flex-wrap: wrap;
    gap: 2em;
}

/* Two Column Layout */
.wp-block-columns.has-2-columns,
.wp-block-columns.is-layout-flex.wp-container-columns-is-layout-2-col {
    gap: 2em;
}

.wp-block-column {
    flex-grow: 1;
    min-width: 0;
    word-break: break-word;
    overflow-wrap: break-word;
}

/* Equal width columns */
@media (min-width: 782px) {

    .wp-block-columns.has-2-columns>.wp-block-column,
    .wp-block-columns.is-layout-flex.wp-container-columns-is-layout-2-col>.wp-block-column {
        flex-basis: calc(50% - 1em);
        flex-grow: 0;
    }

    /* Handle custom column ratios */
    .wp-block-columns.has-2-columns>.wp-block-column[style*="flex-basis"],
    .wp-block-columns.is-layout-flex.wp-container-columns-is-layout-2-col>.wp-block-column[style*="flex-basis"] {
        flex-grow: 0;
    }
}

/* Tablet breakpoint */
@media (max-width: 781px) and (min-width: 600px) {

    .wp-block-columns.has-2-columns,
    .wp-block-columns.is-layout-flex.wp-container-columns-is-layout-2-col {
        gap: 1.5em;
    }

    .wp-block-columns.has-2-columns>.wp-block-column,
    .wp-block-columns.is-layout-flex.wp-container-columns-is-layout-2-col>.wp-block-column {
        flex-basis: calc(50% - 0.75em) !important;
        flex-grow: 0;
    }
}

/* Mobile breakpoint */
@media (max-width: 599px) {

    .wp-block-columns.has-2-columns,
    .wp-block-columns.is-layout-flex.wp-container-columns-is-layout-2-col {
        gap: 1em;
    }

    .wp-block-columns.has-2-columns>.wp-block-column,
    .wp-block-columns.is-layout-flex.wp-container-columns-is-layout-2-col>.wp-block-column {
        flex-basis: 100% !important;
        margin-left: 0;
    }
}

/* Inner block spacing within columns */
.wp-block-column>* {
    margin-top: 0;
    margin-bottom: 1.75em;
}

.wp-block-column>*:first-child {
    margin-top: 0;
}

.wp-block-column>*:last-child {
    margin-bottom: 0;
}

/* Handle nested columns */
.wp-block-column .wp-block-columns {
    margin-bottom: 0;
}

/* Column content alignment */
.wp-block-column.is-vertically-aligned-top {
    align-self: flex-start;
}

.wp-block-column.is-vertically-aligned-center {
    align-self: center;
}

.wp-block-column.is-vertically-aligned-bottom {
    align-self: flex-end;
}

/* Support for background colors in columns */
.wp-block-column.has-background {
    padding: 1.25em;
    border-radius: 4px;
}

@media (max-width: 599px) {
    .wp-block-column.has-background {
        padding: 1em;
    }
}