/* ═══════════════════════════════════════════════════════════════
 * Finboard Mod Toolkit — modal, kebab, mute banner
 *
 * Self-contained token declarations so the kebab menu / modal can
 * be appended to <body> (escape transformed ancestors) or rendered
 * inside WP admin without depending on finboard-v4.css being in
 * scope.
 * ═══════════════════════════════════════════════════════════════ */

.finboard-mod-kebab__menu,
.finboard-mod-modal {
    /* Default (light) tokens — used when nothing else resolves. */
    --fb-bg:      #ffffff;
    --fb-text:    #1a1d25;
    --fb-muted:   #5e6578;
    --fb-card:    #ffffff;
    --fb-border:  rgba(0,0,0,0.12);
    --fb-gold:    #c4920a;
}

/* Dark mode via system preference */
@media (prefers-color-scheme: dark) {
    .finboard-mod-kebab__menu,
    .finboard-mod-modal {
        --fb-bg:     #1e2230;
        --fb-text:   #e8ecf4;
        --fb-muted:  #9ca3b4;
        --fb-card:   #1e2230;
        --fb-border: rgba(255,255,255,0.10);
        --fb-gold:   #E8A910;
    }
}

/* Dark mode via explicit toggle (overrides system pref) */
html[data-finboard-theme="dark"] .finboard-mod-kebab__menu,
html[data-finboard-theme="dark"] .finboard-mod-modal,
[data-finboard-theme="dark"] .finboard-mod-kebab__menu,
[data-finboard-theme="dark"] .finboard-mod-modal {
    --fb-bg:     #1e2230;
    --fb-text:   #e8ecf4;
    --fb-muted:  #9ca3b4;
    --fb-card:   #1e2230;
    --fb-border: rgba(255,255,255,0.10);
    --fb-gold:   #E8A910;
}

/* Dark mode shadow overrides — stronger contrast on dark backgrounds */
@media (prefers-color-scheme: dark) {
    .finboard-mod-kebab__menu,
    .finboard-mod-modal__dialog {
        box-shadow:
            0 0 0 1px rgba(255,255,255,0.06),
            0 16px 40px rgba(0,0,0,0.55),
            0 4px 12px rgba(0,0,0,0.35);
    }
}
html[data-finboard-theme="dark"] .finboard-mod-kebab__menu,
html[data-finboard-theme="dark"] .finboard-mod-modal__dialog,
[data-finboard-theme="dark"] .finboard-mod-kebab__menu,
[data-finboard-theme="dark"] .finboard-mod-modal__dialog {
    box-shadow:
        0 0 0 1px rgba(255,255,255,0.06),
        0 16px 40px rgba(0,0,0,0.55),
        0 4px 12px rgba(0,0,0,0.35);
}

/* Light mode via explicit toggle */
html[data-finboard-theme="light"] .finboard-mod-kebab__menu,
html[data-finboard-theme="light"] .finboard-mod-modal,
[data-finboard-theme="light"] .finboard-mod-kebab__menu,
[data-finboard-theme="light"] .finboard-mod-modal {
    --fb-bg:      #ffffff;
    --fb-text:    #1a1d25;
    --fb-muted:   #5e6578;
    --fb-card:    #ffffff;
    --fb-border:  rgba(0,0,0,0.12);
    --fb-gold:    #c4920a;
}

/* WP admin — always light chrome regardless of frontend theme, since the
   admin page itself is light. */
body.wp-admin .finboard-mod-kebab__menu,
body.wp-admin .finboard-mod-modal {
    --fb-bg:      #ffffff;
    --fb-text:    #1a1d25;
    --fb-muted:   #5e6578;
    --fb-card:    #ffffff;
    --fb-border:  rgba(0,0,0,0.12);
    --fb-gold:    #c4920a;
}

/* ── Modal ── */
.finboard-mod-modal[hidden] { display: none !important; }
.finboard-mod-modal {
    position: fixed; inset: 0;
    display: flex; align-items: center; justify-content: center;
    z-index: 100000;
}
.finboard-mod-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(0,0,0,.55);
}
.finboard-mod-modal__dialog {
    position: relative;
    background: var(--fb-bg);
    color: var(--fb-text);
    max-width: 560px; width: calc(100% - 32px);
    max-height: calc(100vh - 48px);
    overflow: auto;
    border-radius: 10px;
    box-shadow:
        0 0 0 1px rgba(0,0,0,0.04),
        0 12px 32px rgba(0,0,0,0.18),
        0 4px 12px rgba(0,0,0,0.08);
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    -webkit-font-smoothing: antialiased;
}
.finboard-mod-modal__header,
.finboard-mod-modal__footer {
    display: flex; justify-content: space-between; align-items: center;
    padding: 14px 18px;
    border-bottom: 1px solid rgba(0,0,0,.1);
}
.finboard-mod-modal__footer {
    border-bottom: 0; border-top: 1px solid rgba(0,0,0,.1);
}
.finboard-mod-modal__body { padding: 16px 18px; }
.finboard-mod-modal__close {
    background: none; border: 0; font-size: 24px; cursor: pointer;
    line-height: 1; padding: 4px 8px;
}
.finboard-mod-modal__title { margin: 0; font-size: 18px; }
.finboard-mod-modal__history { margin-bottom: 16px; }
.finboard-mod-modal__history h3 { margin: 0 0 8px; font-size: 14px; }
.finboard-mod-modal__history-list {
    max-height: 140px; overflow-y: auto;
    border: 1px solid rgba(0,0,0,.1); border-radius: 6px;
    padding: 8px 10px; font-size: 13px;
    background: rgba(0,0,0,.02);
}
.finboard-mod-modal__history-row {
    display: flex; gap: 10px; padding: 4px 0;
    border-bottom: 1px solid rgba(0,0,0,.06);
}
.finboard-mod-modal__history-row:last-child { border-bottom: 0; }
.finboard-mod-modal__history-row time { flex-shrink: 0; opacity: .7; }

.finboard-mod-modal__form label { display: block; margin-bottom: 12px; }
.finboard-mod-modal__form label > span {
    display: block; font-weight: 600; margin-bottom: 4px; font-size: 13px;
}
.finboard-mod-modal__form select,
.finboard-mod-modal__form textarea {
    width: 100%; box-sizing: border-box; padding: 8px;
    border: 1px solid rgba(0,0,0,.2); border-radius: 4px;
    font: inherit;
}
.finboard-mod-modal__duration,
.finboard-mod-modal__scope {
    border: 1px solid rgba(0,0,0,.15); border-radius: 6px;
    padding: 10px 12px; margin-bottom: 12px;
}
.finboard-mod-modal__duration legend,
.finboard-mod-modal__scope legend {
    font-weight: 600; padding: 0 4px; font-size: 13px;
}
.finboard-mod-modal__duration label,
.finboard-mod-modal__scope label {
    display: inline-flex; gap: 4px; margin: 0 12px 4px 0; font-size: 13px;
}
.finboard-mod-modal__error {
    color: #b91c1c; background: rgba(185,28,28,.08);
    border: 1px solid rgba(185,28,28,.25); border-radius: 4px;
    padding: 8px 10px; margin-top: 8px; font-size: 13px;
}
.finboard-mod-modal__error[hidden] { display: none; }

/* ── Topic-page kebab ── */
.finboard-mod-kebab-wrap {
    position: relative;
    display: inline-block;
    overflow: visible;   /* defensive — never clip the dropdown */
}
/* Kebab trigger — reset inherited .finboard-action-btn chrome. */
.finboard-action-btn.finboard-mod-kebab,
.finboard-mod-kebab {
    padding: 4px 10px !important;
    min-height: 0 !important;
    height: auto !important;
    line-height: 1 !important;
    font-size: 18px !important;
    letter-spacing: 1px;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    color: inherit;
    cursor: pointer;
    opacity: 0.65;
    transition: opacity .15s, color .15s;
    border-radius: 4px;
}
.finboard-action-btn.finboard-mod-kebab:hover,
.finboard-action-btn.finboard-mod-kebab:focus-visible,
.finboard-mod-kebab:hover,
.finboard-mod-kebab:focus-visible {
    opacity: 1;
    color: var(--fb-gold) !important;
    background: transparent !important;
    outline: none;
}
.finboard-mod-kebab__menu {
    position: fixed !important;
    z-index: 2147483000 !important;  /* just below max int — beats any theme/plugin */
    min-width: 220px;
    max-width: 320px;
    background: var(--fb-bg);
    color: var(--fb-text);
    border: 1px solid var(--fb-border);
    border-radius: 10px;
    box-shadow:
        0 0 0 1px rgba(0,0,0,0.04),              /* micro ring for edge definition */
        0 12px 32px rgba(0,0,0,0.18),
        0 4px 12px rgba(0,0,0,0.08);
    padding: 6px 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    font-size: 14px;
    line-height: 1.4;
    -webkit-font-smoothing: antialiased;
    /* top + left set inline by JS */
}
.finboard-mod-kebab__menu[hidden] {
    display: none !important;
}
.finboard-mod-kebab__group-label {
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 10px 14px 4px;
    opacity: 0.5;
    user-select: none;
}
.finboard-mod-kebab__item {
    display: flex !important;
    align-items: center;
    gap: 10px;
    width: 100%;
    text-align: left;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 9px 14px;
    min-height: 38px;
    font: inherit;
    font-size: 14px;
    font-weight: 500;
    color: inherit;
    cursor: pointer;
    transition: background .15s, color .15s;
    text-decoration: none !important;
    box-shadow: none !important;
    letter-spacing: 0;
    line-height: 1.3;
}
.finboard-mod-kebab__item:hover,
.finboard-mod-kebab__item:focus-visible {
    background: rgba(232, 169, 16, 0.12) !important;
    color: var(--fb-gold) !important;
    outline: none;
}
.finboard-mod-kebab__item--danger {
    color: #ef6b6b !important;
}
.finboard-mod-kebab__item--danger:hover,
.finboard-mod-kebab__item--danger:focus-visible {
    background: rgba(239, 107, 107, 0.14) !important;
    color: #ef4444 !important;
}
.finboard-mod-kebab__item-icon {
    width: 15px;
    height: 15px;
    flex-shrink: 0;
    opacity: 0.7;
    stroke: currentColor;
    fill: none;
    transition: opacity .15s;
}
.finboard-mod-kebab__item:hover .finboard-mod-kebab__item-icon,
.finboard-mod-kebab__item:focus-visible .finboard-mod-kebab__item-icon {
    opacity: 1;
}
.finboard-mod-kebab__sep {
    border: 0;
    border-top: 1px solid var(--fb-border);
    margin: 4px 8px;
}

/* First and last items round to match menu corners. */
.finboard-mod-kebab__menu > .finboard-mod-kebab__item:first-child {
    border-top-left-radius: 9px;
    border-top-right-radius: 9px;
}
.finboard-mod-kebab__menu > .finboard-mod-kebab__item:last-child {
    border-bottom-left-radius: 9px;
    border-bottom-right-radius: 9px;
}

/* Mobile: larger tap targets, full width */
@media (max-width: 480px) {
    .finboard-mod-kebab__item {
        min-height: 44px;
        padding: 12px 18px;
        font-size: 15px;
    }
    .finboard-mod-kebab__group-label {
        padding: 12px 18px 6px;
        font-size: 12px;
    }
}

/* When a kebab wrap lives inside card containers, prevent clipping. */
.finboard-post-actions,
.finboard-comment__actions,
.finboard-dc-topic-card,
.finboard-comment,
article.finboard-comment,
article.finboard-dc-post {
    overflow: visible !important;
}

/* ── Mute-status banner (Settings tab) ── */
.finboard-mod-mute-banner {
    border: 1px solid #d97706;
    background: rgba(217,119,6,.08);
    padding: 12px 16px;
    border-radius: 6px;
    margin-bottom: 16px;
    font-size: 14px;
}
.finboard-mod-mute-banner strong { color: #92400e; }

/* WP admin button reset — kebab trigger + menu items must not pick up
   the .wp-core-ui .button chrome that admin applies globally. */
body.wp-admin .finboard-mod-kebab,
body.wp-admin .finboard-mod-kebab__item,
body.wp-admin .finboard-mod-modal__close,
body.wp-admin .finboard-mod-modal__submit {
    line-height: inherit;
    text-shadow: none;
    box-shadow: none;
}
body.wp-admin .finboard-mod-kebab {
    background: transparent;
    border: 0;
    padding: 4px 10px;
    min-height: 0;
    height: auto;
    color: var(--fb-text);
}
body.wp-admin .finboard-mod-kebab:hover,
body.wp-admin .finboard-mod-kebab:focus {
    background: transparent;
    border: 0;
    color: var(--fb-gold);
    box-shadow: none;
}
body.wp-admin .finboard-mod-kebab__item {
    background: none;
    border: 0;
    border-radius: 0;
    padding: 10px 16px;
    min-height: 40px;
    color: inherit;
}
