/* ============================================================
 * outsend UI · dropdown.css
 * ============================================================
 * Composant dropdown menu réutilisable : un trigger qui toggle
 * un menu absolu d'items (liens ou boutons).
 *
 * Utilisation HTML (avec Alpine pour le toggle) :
 *   <div class="ui-dropdown" x-data="{ open: false }" @click.outside="open = false"
 *        @keydown.escape.window="open = false">
 *     <button class="ui-dropdown-trigger" @click="open = !open" type="button">
 *       Actions
 *       <span x-text="open ? '▴' : '▾'"></span>
 *     </button>
 *     <div class="ui-dropdown-menu is-right" x-show="open" x-cloak x-transition.opacity>
 *       <a href="/foo" @click="open = false">Item 1</a>
 *       <a href="/bar" @click="open = false">Item 2</a>
 *     </div>
 *   </div>
 *
 * Variants disponibles sur .ui-dropdown-menu :
 *   .is-right  → aligne le menu à droite du trigger
 *   .is-left   → aligne à gauche (défaut)
 *
 * Variables CSS utilisées (style.css) :
 *   --bg, --border, --r-md, --accent-soft, --accent-text, --ink
 * ============================================================ */

.ui-dropdown {
    position: relative;
    display: inline-block;
}

.ui-dropdown-trigger {
    background: transparent;
    border: 0;
    padding: 0;
    cursor: pointer;
    font: inherit;
    color: inherit;
}

.ui-dropdown-menu {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 220px;
    background: var(--bg, #fff);
    border: 1px solid var(--border);
    border-radius: var(--r-md, 6px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.10), 0 1px 3px rgba(0, 0, 0, 0.04);
    padding: 6px;
    z-index: 30;
    transition: opacity 0.15s;
}

.ui-dropdown-menu.is-right {
    left: auto;
    right: 0;
}

.ui-dropdown-menu.is-left {
    left: 0;
    right: auto;
}

.ui-dropdown-menu a,
.ui-dropdown-menu button {
    display: flex;
    flex-direction: column;
    gap: 2px;
    width: 100%;
    text-align: left;
    padding: 10px 12px;
    border-radius: 6px;
    text-decoration: none;
    color: var(--ink, #1a1a1a);
    background: transparent;
    border: 0;
    font: inherit;
    font-size: 13px;
    cursor: pointer;
    transition: background 0.12s, color 0.12s;
}

.ui-dropdown-menu a:hover,
.ui-dropdown-menu button:hover {
    background: var(--accent-soft, #DEEDED);
    color: var(--accent-text, #094543);
}

.ui-dropdown-menu a strong,
.ui-dropdown-menu button strong {
    font-weight: 600;
    font-size: 13px;
}

.ui-dropdown-menu a .text-xs,
.ui-dropdown-menu button .text-xs {
    font-size: 11px;
    line-height: 1.3;
}

/* Séparateur entre items */
.ui-dropdown-menu hr,
.ui-dropdown-menu .ui-dropdown-separator {
    border: 0;
    border-top: 1px solid var(--border);
    margin: 4px 0;
}

@media (max-width: 720px) {
    .ui-dropdown-menu {
        min-width: 200px;
    }
    .ui-dropdown-menu.is-right {
        right: -8px;
    }
}

/* ============================================================
 * Variante "split button" : action principale (lien direct vers
 * format par défaut) + caret pour ouvrir les autres formats.
 * Utilisé sur la page détail d'un job pour le téléchargement.
 * ============================================================ */

.ui-dropdown.dl-split {
    display: inline-flex;
    align-items: stretch;
    vertical-align: middle;
}

.ui-dropdown.dl-split .dl-split-main {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    padding-right: 10px;
    text-decoration: none;
}

.ui-dropdown.dl-split .dl-split-caret {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-left: 1px solid rgba(255, 255, 255, 0.22);
    padding-left: 8px;
    padding-right: 8px;
    min-width: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Compteur de résultats dans le bouton principal */
.ui-dropdown.dl-split .dl-split-count {
    display: inline-flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.22);
    color: inherit;
    padding: 1px 7px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 700;
    font-family: var(--font-mono, monospace);
    margin-left: 2px;
}

/* Petite pastille de status (live / partiel) à droite du compteur */
.ui-dropdown.dl-split .dl-split-pill {
    display: inline-flex;
    align-items: center;
    padding: 1px 7px;
    border-radius: 10px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-left: 4px;
}

.ui-dropdown.dl-split .dl-split-pill-live {
    background: #fff;
    color: var(--accent, #0D5D5C);
    animation: dl-split-live-blink 1.4s ease-in-out infinite;
}

.ui-dropdown.dl-split .dl-split-pill-partial {
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
}

@keyframes dl-split-live-blink {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.55; }
}

/* Position du menu : à droite du caret */
.ui-dropdown.dl-split .ui-dropdown-menu.is-right {
    top: calc(100% + 6px);
    right: 0;
}
