/* ==========================================================================
   Gutenberg Block Styles — Asia Finest Dark Theme
   Ensures WordPress core blocks render correctly on the dark background.
   ========================================================================== */

/* --------------------------------------------------------------------------
   General block alignment & width
   -------------------------------------------------------------------------- */

.wp-block-group.has-background {
    padding: var(--af-space-normal) 24px;
    border-radius: var(--af-radius);
}

.wp-block-group.alignfull {
    border-radius: 0;
}

/* Constrain content blocks */
.entry-content > *,
.af-entry-content > * {
    max-width: var(--af-max);
    margin-left: auto;
    margin-right: auto;
}

.af-entry-content > .alignwide {
    max-width: calc(var(--af-max) + 120px);
}

.af-entry-content > .alignfull {
    max-width: none;
}

/* --------------------------------------------------------------------------
   Buttons block
   -------------------------------------------------------------------------- */

.wp-block-button .wp-block-button__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 20px;
    border-radius: 12px;
    font-weight: 600;
    font-size: 14px;
    font-family: var(--af-sans);
    letter-spacing: .01em;
    transition: all .2s ease;
    text-decoration: none;
}

/* Default / outline style */
.wp-block-button.is-style-outline .wp-block-button__link {
    border: 1px solid rgba(248, 248, 248, .16);
    background: rgba(248, 248, 248, .06);
    color: var(--af-ivory);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
    background: rgba(248, 248, 248, .10);
}

/* Fill style (primary) */
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
    background: var(--af-gold);
    color: #0b0b0b;
    border: 1px solid rgba(255, 255, 255, .16);
}

.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
    filter: brightness(1.04);
}

/* Buttons group spacing */
.wp-block-buttons {
    gap: 12px;
}

/* --------------------------------------------------------------------------
   Separator / HR
   -------------------------------------------------------------------------- */

.wp-block-separator {
    border: none;
    border-top: 1px solid rgba(248, 248, 248, .10);
    margin: var(--af-space-normal) auto;
    opacity: 1;
}

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

.wp-block-separator.is-style-dots {
    border: none;
    text-align: center;
    color: var(--af-gold);
}

/* --------------------------------------------------------------------------
   Quote block
   -------------------------------------------------------------------------- */

.wp-block-quote {
    border-left: 3px solid var(--af-gold);
    padding: .8em 1.2em;
    margin: 1.5em 0;
    font-style: italic;
    font-family: var(--af-serif);
    font-size: 18px;
    color: rgba(248, 248, 248, .85);
}

.wp-block-quote p {
    margin-bottom: .6em;
}

.wp-block-quote cite,
.wp-block-quote .wp-block-quote__citation {
    display: block;
    font-style: normal;
    font-family: var(--af-sans);
    font-size: 13px;
    color: var(--af-stone);
    margin-top: .4em;
}

.wp-block-quote.is-style-large {
    border-left: none;
    padding: 0;
    text-align: center;
    font-size: clamp(22px, 3vw, 30px);
}

/* --------------------------------------------------------------------------
   Pullquote
   -------------------------------------------------------------------------- */

.wp-block-pullquote {
    border-top: 3px solid var(--af-gold);
    border-bottom: 3px solid var(--af-gold);
    padding: var(--af-space-compact) 0;
    text-align: center;
}

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

.wp-block-pullquote p {
    font-family: var(--af-serif);
    font-size: clamp(24px, 3vw, 32px);
    font-style: italic;
    max-width: 50ch;
    margin: 0 auto;
}

/* --------------------------------------------------------------------------
   Image block
   -------------------------------------------------------------------------- */

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

.wp-block-image figcaption {
    font-size: 13px;
    color: rgba(248, 248, 248, .60);
    text-align: center;
    margin-top: 8px;
}

/* --------------------------------------------------------------------------
   Gallery
   -------------------------------------------------------------------------- */

.wp-block-gallery {
    gap: 8px;
}

.wp-block-gallery .wp-block-image img {
    border-radius: calc(var(--af-radius) / 2);
}

.wp-block-gallery figcaption {
    color: rgba(248, 248, 248, .70);
    font-size: 13px;
    background: linear-gradient(transparent, rgba(16, 16, 16, .80));
}

/* --------------------------------------------------------------------------
   Cover block
   -------------------------------------------------------------------------- */

.wp-block-cover {
    border-radius: var(--af-radius);
    overflow: hidden;
    min-height: 300px;
}

.wp-block-cover.alignfull {
    border-radius: 0;
}

.wp-block-cover__inner-container {
    max-width: var(--af-max);
}

.wp-block-cover p,
.wp-block-cover h1,
.wp-block-cover h2,
.wp-block-cover h3 {
    color: var(--af-ivory);
}

/* --------------------------------------------------------------------------
   Columns block
   -------------------------------------------------------------------------- */

.wp-block-columns {
    gap: 24px;
    margin-bottom: var(--af-space-normal);
}

.wp-block-column {
    margin-bottom: 0;
}

/* --------------------------------------------------------------------------
   Media & Text block
   -------------------------------------------------------------------------- */

.wp-block-media-text {
    border-radius: var(--af-radius);
    overflow: hidden;
    border: 1px solid rgba(248, 248, 248, .10);
    background: rgba(248, 248, 248, .03);
}

.wp-block-media-text .wp-block-media-text__content {
    padding: 24px;
}

/* --------------------------------------------------------------------------
   Table block
   -------------------------------------------------------------------------- */

.wp-block-table table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

.wp-block-table th {
    font-weight: 600;
    text-align: left;
    padding: 12px 16px;
    border-bottom: 2px solid rgba(248, 248, 248, .14);
    color: var(--af-ivory);
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.wp-block-table td {
    padding: 12px 16px;
    border-bottom: 1px solid rgba(248, 248, 248, .06);
    color: rgba(248, 248, 248, .82);
}

.wp-block-table tr:last-child td {
    border-bottom: none;
}

.wp-block-table.is-style-stripes tbody tr:nth-child(odd) {
    background: rgba(248, 248, 248, .03);
}

/* --------------------------------------------------------------------------
   Code / Preformatted blocks
   -------------------------------------------------------------------------- */

.wp-block-code {
    background: rgba(248, 248, 248, .04);
    padding: 1.2em 1.4em;
    border-radius: 12px;
    border: 1px solid rgba(248, 248, 248, .08);
    font-size: 14px;
    overflow-x: auto;
}

.wp-block-code code {
    color: var(--af-sand);
    background: none;
    padding: 0;
}

.wp-block-preformatted {
    background: rgba(248, 248, 248, .04);
    padding: 1.2em 1.4em;
    border-radius: 12px;
    font-size: 14px;
}

/* --------------------------------------------------------------------------
   List block
   -------------------------------------------------------------------------- */

.wp-block-list {
    max-width: 75ch;
    padding-left: 1.4em;
}

.wp-block-list li {
    margin-bottom: .4em;
}

.wp-block-list li::marker {
    color: var(--af-gold);
}

/* --------------------------------------------------------------------------
   Details / Accordion
   -------------------------------------------------------------------------- */

.wp-block-details {
    border: 1px solid rgba(248, 248, 248, .10);
    border-radius: 14px;
    padding: 0;
    margin-bottom: 8px;
}

.wp-block-details summary {
    padding: 16px 20px;
    font-weight: 600;
    cursor: pointer;
    font-family: var(--af-sans);
}

.wp-block-details[open] summary {
    border-bottom: 1px solid rgba(248, 248, 248, .08);
}

.wp-block-details > *:not(summary) {
    padding: 16px 20px;
}

/* --------------------------------------------------------------------------
   Spacer
   -------------------------------------------------------------------------- */

.wp-block-spacer {
    /* Inherit — no visual change needed */
}

/* --------------------------------------------------------------------------
   Embed / Video
   -------------------------------------------------------------------------- */

.wp-block-embed {
    border-radius: var(--af-radius);
    overflow: hidden;
}

.wp-block-video video {
    border-radius: var(--af-radius);
}

/* --------------------------------------------------------------------------
   Custom HTML block — theme components
   The import content uses af- classes inside Custom HTML blocks.
   These are already styled by components.css, pages.css, etc.
   -------------------------------------------------------------------------- */
