/* ==========================================================================
   LAYOUT — Containers, Grid, Wrappers
   ========================================================================== */

.container {
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--space-lg);
}

.container--narrow {
    max-width: var(--container-narrow);
}

.container--mid {
    max-width: var(--container-mid);
}

/* Site wrapper */
.site {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.site-main {
    flex: 1;
    padding-block: var(--space-2xl);
}

/* Front page — hero sits flush against the header */
body.home .site-main {
    padding-block-start: 0;
    padding-block-end: 0;
}

/* Single post — article-header handles its own top spacing */
body.single .site-main {
    padding-block-start: 0;
}

/* Generic grids */
.posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
    gap: var(--space-xl);
}

.posts-grid--2 {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 480px), 1fr));
}

/* Section label utility */
.section-label {
    display: inline-block;
    font-family: var(--font-ui);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent);
    padding: 0.2em 0.75em;
    border: 1px solid var(--color-accent);
    border-radius: var(--radius-pill);
    line-height: 1.8;
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.section-label:hover,
.section-label--active {
    background: var(--color-accent);
    color: var(--color-bg);
}

/* Dividers */
.divider {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-block: var(--space-xl);
}

.divider::before,
.divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

/* WordPress alignment classes */
.aligncenter { display: block; margin-inline: auto; }
.alignleft   { float: left; margin: 0 var(--space-lg) var(--space-md) 0; }
.alignright  { float: right; margin: 0 0 var(--space-md) var(--space-lg); }
.alignwide   { max-width: calc(var(--container-narrow) + 200px); margin-inline: auto; }
.alignfull   { width: 100vw; margin-left: calc(50% - 50vw); }

@media (max-width: 600px) {
    .container { padding-inline: var(--space-md); }
    .alignleft, .alignright { float: none; margin: 0 0 var(--space-md); }
}
